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)

}

相关推荐
百锦再1 分钟前
Vue Scoped样式混淆问题详解与解决方案
java·前端·javascript·数据库·vue.js·学习·.net
Sheldon一蓑烟雨任平生41 分钟前
Vue3 表单输入绑定
vue.js·vue3·v-model·vue3 表单输入绑定·表单输入绑定·input和change区别·vue3 双向数据绑定
YUELEI1183 小时前
Vue 安装依赖的集合和小知识
javascript·vue.js·ecmascript
前端付豪4 小时前
万事从 todolist 开始
前端·vue.js·前端框架
华仔啊5 小时前
别再纠结Pinia和Vuex了!一篇文章彻底搞懂区别与选择
前端·vue.js
月弦笙音6 小时前
【Vue3】Keep-Alive 深度解析
前端·vue.js·源码阅读
咖啡の猫7 小时前
Vue 实例生命周期
前端·vue.js·okhttp
JNU freshman8 小时前
vue 之 import 的语法
前端·javascript·vue.js
剑亦未配妥8 小时前
Vue 2 响应式系统常见问题与解决方案(包含_demo以下划线开头命名的变量导致响应式丢失问题)
前端·javascript·vue.js
爱吃的强哥8 小时前
Vue2 封装二维码弹窗组件
javascript·vue.js