From 71cc4a7c66a9caa8f856edc55f16564fe2972a0a Mon Sep 17 00:00:00 2001 From: zhouwenxuan <1175765986@qq.com> Date: 星期二, 12 十二月 2023 17:19:28 +0800 Subject: [PATCH] bug修复 --- src/views/components/laws.vue | 40 +++++++++++++++++++++++++++++----------- 1 files changed, 29 insertions(+), 11 deletions(-) diff --git a/src/views/components/laws.vue b/src/views/components/laws.vue index ab6ef7d..45b2fa8 100644 --- a/src/views/components/laws.vue +++ b/src/views/components/laws.vue @@ -7,27 +7,26 @@ <el-input v-model="state.querys.title" /> </el-form-item> </el-form> - <el-button type="primary" :icon="Search" class="searchBtn">搜索</el-button> - <el-button type="primary" :icon="Refresh" class="resetBtn">重置</el-button> + <el-button type="primary" :icon="Search" class="searchBtn" v-model="state.querys.title" @click="search">搜索</el-button> + <el-button type="primary" :icon="Refresh" class="resetBtn" @click="reset">重置</el-button> </div> <div class="list"> - <div v-for="item in state.dataList"> + <div v-for="item in state.dataList" @click="openDetails('法律法规',item.id)"> <div> <div><img src="src/assets/images/article.png"></div> <div>{{item.title}}</div> </div> <span> - {{item.updateTime}} + {{(item.updateTime?item.updateTime:item.createTime).substring(0,16)}} </span> </div> </div> - <div class="pag-container"> + <div class="pag-container" v-if="state.total&&state.total>0"> <el-pagination - v-model:current-page="state.querys.pageNum" - v-model:page-size="state.querys.pageSize" - :page-sizes="[10,15,20,25]" + :page-sizes="[10,15,20]" layout="total, sizes, prev, pager, next, jumper" :total="state.total" + :current-page="state.querys.pageNum" @size-change="handleSizeChange" @current-change="handleCurrentChange" /> @@ -37,12 +36,12 @@ </template> <script setup> -import {onMounted, ref, reactive, watch, onUnmounted, defineExpose} from "vue" +import {onMounted, ref, reactive, watch, onUnmounted, defineExpose, defineEmits} from "vue" import { getLaws } from '@/api/home/homePage' import useUserStore from '@/store/modules/user' import { Search, Refresh } from '@element-plus/icons-vue' import {ElMessage} from "element-plus"; - +const emit = defineEmits(['openDetails']) const route = useRoute() const router = useRouter() @@ -82,12 +81,29 @@ } const handleSizeChange = (val) => { + state.querys.pageNum = 1; state.querys.pageSize = val getData() } const handleCurrentChange = (val) => { state.querys.pageNum = val getData() +} +const search = () => { + state.querys.pageNum = 1; + getData() +} +const reset = () => { + state.querys = { + title: '', + content: '', + pageNum: 1, + pageSize: 10 + } + getData() +} +const openDetails = (type,id)=>{ + emit('openDetails',type,id) } defineExpose({ @@ -142,6 +158,8 @@ .list{ padding: 15px 0; + max-height: calc(100vh - 402px); + overflow-y: auto; &>div{ display: flex; @@ -171,7 +189,7 @@ } } div:last-of-type{ - width: 1000px; + width: 900px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; -- Gitblit v1.9.2