以下是一个基本的列表页面,包括搜索、分页、操作列、树形结构、多选删除等功能:

<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
    }
  }
}

以上代码仅供参考,具体根据实际需求进行调整和修改

用 vue3 + element plus UI 帮我写一个列表页面。列表满足的要求 1 有搜索功能可以根据输入的关键字 和 状态下拉选项 进行列表的查询。2 有分页功能每页显示 102050 条数据。3 并且列表有一个操作列操作列有两个按钮一个是编辑一个是删除。4 列表的数据是从后端获取的后端接口是 apilist请求方式是 get请求参数是 page 和 pageSize返回的数据格式是 c

原文地址: https://www.cveoy.top/t/topic/chv8 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录