用 vue3 + element plus UI 帮我写一个列表页面。列表满足的要求 1 有搜索功能可以根据输入的关键字 和 状态下拉选项 进行列表的查询。2 有分页功能每页显示 102050 条数据。3 并且列表有一个操作列操作列有两个按钮一个是编辑一个是删除。4 列表的数据是从后端获取的后端接口是 apilist请求方式是 get请求参数是 page 和 pageSize返回的数据格式是 c
以下是一个基本的列表页面,包括搜索、分页、操作列、树形结构、多选删除等功能:
<template>
<div>
<el-form :inline="true">
<el-form-item label="关键字">
<el-input v-model="keyword" placeholder="请输入关键字"></el-input>
</el-form-item>
<el-form-item label="状态">
<el-select v-model="status" placeholder="请选择状态">
<el-option label="全部" value=""></el-option>
<el-option label="状态1" value="1"></el-option>
<el-option label="状态2" value="2"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="search">查询</el-button>
</el-form-item>
</el-form>
<el-table :data="tableData" style="width: 100%">
<el-table-column type="selection"></el-table-column>
<el-table-column prop="name" label="名称"></el-table-column>
<el-table-column prop="status" label="状态"></el-table-column>
<el-table-column label="操作">
<template #default="{ row }">
<el-button type="primary" size="small" @click="edit(row)">编辑</el-button>
<el-button type="danger" size="small" @click="del(row)">删除</el-button>
</template>
</el-table-column>
<el-table-column label="子节点">
<template #default="{ row }">
<el-button type="primary" size="small" v-if="row.children && !row.childrenLoaded" @click="loadChildren(row)">加载子节点</el-button>
<el-tree
v-if="row.children"
:data="row.children"
:props="{ label: 'name', children: 'children', isLeaf: 'isLeaf', expandOnClickNode: false }"
:load="loadSubTree"
:expand-on-click-node="false"
show-checkbox
node-key="id"
@check-change="checkChange"
></el-tree>
</template>
</el-table-column>
</el-table>
<el-pagination
v-if="total > 0"
:total="total"
:page-size="pageSize"
:current-page.sync="currentPage"
@current-change="getPageData"
></el-pagination>
<el-button type="danger" @click="delSelected" style="margin-top: 10px">批量删除</el-button>
</div>
</template>
<script>
import { ref } from 'vue'
import { ElMessage, ElTable, ElTableColumn, ElButton, ElPagination, ElForm, ElFormItem, ElInput, ElSelect, ElOption, ElTree } from 'element-plus'
export default {
components: { ElMessage, ElTable, ElTableColumn, ElButton, ElPagination, ElForm, ElFormItem, ElInput, ElSelect, ElOption, ElTree },
setup() {
const keyword = ref('')
const status = ref('')
const tableData = ref([])
const total = ref(0)
const currentPage = ref(1)
const pageSize = ref(10)
const selectedRows = ref([])
const search = () => {
currentPage.value = 1
getPageData()
}
const getPageData = () => {
// 根据当前页和每页条数获取数据
const params = {
page: currentPage.value,
pageSize: pageSize.value,
keyword: keyword.value,
status: status.value
}
// 模拟请求数据
const data = { code: 0, data: { total: 20, list: [] } }
for (let i = 0; i < pageSize.value; i++) {
data.data.list.push({
id: i + (currentPage.value - 1) * pageSize.value,
name: `名称${i + (currentPage.value - 1) * pageSize.value}`,
status: i % 2 === 0 ? '状态1' : '状态2'
})
}
tableData.value = data.data.list
total.value = data.data.total
}
const edit = (row) => {
// 编辑操作
}
const del = (row) => {
// 删除操作
}
const delSelected = () => {
// 批量删除操作
if (selectedRows.value.length === 0) {
ElMessage.warning('请选择要删除的数据')
return
}
// 删除选中的数据
const newData = tableData.value.filter(item => !selectedRows.value.includes(item))
tableData.value = newData
total.value = newData.length
selectedRows.value = []
}
const loadSubTree = (node, resolve) => {
// 加载子树
const params = { id: node.data.id }
// 模拟请求数据
const data = { code: 0, data: [] }
for (let i = 0; i < 10; i++) {
data.data.push({
id: `${node.data.id}-${i}`,
name: `${node.data.name}-子节点-${i}`,
isLeaf: i === 9
})
}
node.data.children = data.data
node.data.childrenLoaded = true
resolve(data.data)
}
const loadChildren = (row) => {
// 加载子节点
const params = { id: row.id }
// 模拟请求数据
const data = { code: 0, data: [] }
for (let i = 0; i < 10; i++) {
data.data.push({
id: `${row.id}-${i}`,
name: `${row.name}-子节点-${i}`,
isLeaf: i === 9
})
}
row.children = data.data
row.childrenLoaded = true
}
const checkChange = (checkedKeys, info) => {
// 多选操作
selectedRows.value = info.checkedNodes.map(node => node.data)
}
// 初始化数据
getPageData()
return {
keyword,
status,
tableData,
total,
currentPage,
pageSize,
search,
getPageData,
edit,
del,
loadSubTree,
loadChildren,
checkChange,
delSelected,
selectedRows
}
}
}
以上代码仅供参考,具体根据实际需求进行调整和修改
原文地址: https://www.cveoy.top/t/topic/chv8 著作权归作者所有。请勿转载和采集!