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)

}

相关推荐
代码不加糖6 小时前
js中不会冒泡的事件有哪些?
前端·javascript·vue.js
懂懂tty6 小时前
Vue2与Vue3之间API差异
前端·javascript·vue.js
老毛肚7 小时前
软件测试期末考试
vue.js
杨若瑜8 小时前
本地开发环境慢?localhost的锅!
vue.js
xsbcme12 小时前
VueTabRouter 插件实践(一):多标签页不是一排 TabBar
vue.js
云水一下13 小时前
Vue.js从零到精通系列(三):组件化基础——Props、Emits、插槽与生命周期
前端·javascript·vue.js
英勇无比的消炎药16 小时前
少踩坑TinyVue插槽事件编码规范详解
vue.js
2401_8685347817 小时前
5G和4G接入网对比介绍
vue.js
chushiyunen17 小时前
vue export default
前端·javascript·vue.js
北极星日淘18 小时前
可买免税店货物与安耐晒——特殊商品代购技术方案
javascript·vue.js·elementui