vue+elementPlus实现表格展示序号并且翻页不重新排

javascript 复制代码
<template>
  <el-table :data="tableData" style="width: 100%">
    <el-table-column type="index" :index="indexMethod" />
    <el-table-column prop="date" label="Date" width="180" />
    <el-table-column prop="name" label="Name" width="180" />
    <el-table-column prop="address" label="Address" />
  </el-table>
  <el-pagination
   v-model:page-size="params.pageSize"
   background
   layout="prev, pager, next"
   size="small"
   :total="4"
    @current-change="handleCurrentChange"
   />
</template>

<script lang="ts" setup>
import {ref} from 'vue';
// index+1 代表从1开始排序
const indexMethod = (index: number) => {
  return (params.pageNo - 1) * params.pageSize + (index + 1)
}
const params = {
    pageNo: 1,
    pageSize: 3
}
let tableData = ref([
  {
    date: '2015-05-03',
    name: 'Tom',
    state: 'California',
    city: 'Los Angeles',
    address: 'No. 189, Grove St, Los Angeles',
    zip: 'CA 90036',
    tag: 'Home',
  },
  {
    date: '2016-05-02',
    name: 'Tom',
    state: 'California',
    city: 'Los Angeles',
    address: 'No. 189, Grove St, Los Angeles',
    zip: 'CA 90036',
    tag: 'Office',
  },
  {
    date: '2017-05-04',
    name: 'Tom',
    state: 'California',
    city: 'Los Angeles',
    address: 'No. 189, Grove St, Los Angeles',
    zip: 'CA 90036',
    tag: 'Home',
  }
])
const handleCurrentChange = (val) =>{
  params.pageNo = val;
  tableData.value = [
   {
    date: '2018-05-01',
    name: 'Tom',
    state: 'California',
    city: 'Los Angeles',
    address: 'No. 189, Grove St, Los Angeles',
    zip: 'CA 90036',
    tag: 'Office',
  }, {
    date: '2019-05-03',
    name: 'Tom',
    state: 'California',
    city: 'Los Angeles',
    address: 'No. 189, Grove St, Los Angeles',
    zip: 'CA 90036',
    tag: 'Home',
  },
  {
    date: '2020-05-02',
    name: 'Tom',
    state: 'California',
    city: 'Los Angeles',
    address: 'No. 189, Grove St, Los Angeles',
    zip: 'CA 90036',
    tag: 'Office',
  }
  ]
}
</script>

排序翻页不重新从1开始

<el-table-column type="index" :index="indexMethod" />

// index+1 代表从1开始排序

const indexMethod = (index: number) => {

return (params.pageNo - 1) * params.pageSize + (index + 1)

}

相关推荐
资深前端之路16 分钟前
vue+threeJs 绘制3D圆形
前端·javascript·vue.js
Nymph_Zhu1 小时前
vue3+element-plus el-date-picker日期、年份筛选设置本周、本月、近3年等快捷筛选
前端·vue.js·elementui
blues_C3 小时前
九、【前后端联调篇】Vue3 + Axios 异步通信实战
vue.js·后端·django·axios·drf·测试平台
Sunny_lxm3 小时前
在 Vue 2中使用 dhtmlxGantt 7.1.13组件,并解决使用时遇到的问题汇总.“dhtmlx-gantt“: “^7.1.13“,
前端·vue.js·甘特图·dhtmlxgantt
1024小神5 小时前
vue3 项目配置多语言支持,如何从服务端拿多语言配置
前端·javascript·vue.js
Data_Adventure6 小时前
Vue 3 项目文件夹和文件命名最佳实践
vue.js
萌萌哒草头将军6 小时前
苏醒吧,Remix!好消息,Remix将基于Preact 重构,更快更轻量!🚀🚀🚀
前端·vue.js·react.js
Aspirin_Slash7 小时前
【Tauri2.0教程(十一)】让APP关联文件格式右键打开
vue.js
snow@li7 小时前
AI问答-Vue3+TS:reactive创建一个响应式数组,用一个新的数组对象来替换它,同时保持响应性
前端·javascript·vue.js
Z_Wonderful7 小时前
react/vue移动端项目,刷新页面404的原因以及解决办法
前端·vue.js·react.js