vue中el-table列表分页、倒序排序

本文展示了如何在Vue.js中创建一个带有搜索、排序和分页功能的表格。通过使用Element UI库,实现了表格数据的显示、时间戳的降序排列以及分页操作。代码示例详细解释了数据结构和方法调用,为前端开发提供了一个实用的参考模板。
摘要由CSDN通过智能技术生成

template:

/*
*   数据过于真实,有些不便于展示,仅供参考思路,大致写法
*  
*/
<el-form
    :inline="true"
    @submit.native.prevent
    @keyup.enter.native="getProtectorList()"
    label-width="120px"
>
    <el-form-item>
        <el-button
          size="small"
          icon="el-icon-search"
          @click="protectorQuerySearch"
          >查询
        </el-button>
    </el-form-item>
</el-form>
<el-table
    :data="protectorList"
    border
     style="width: 100%"
    :stripe="true"
    :max-height="scorllTableHeight"
    :header-cell-style="tableHeaderColor"
    :cell-style="tableColumnStyle"
    @sort-change="sortChange"
>
    <el-table-column
          fixed
          prop="devShowName"
          label="名称"
          header-align="center"
          align="center"
          width="140"
          :show-overflow-tooltip="true"
    ></el-table-column>
    <el-table-column
          fixed
          prop="dbtime"
          label="时间"
          header-align="center"
          align="center"
          min-width="160"
          sortable="custom"
          :show-overflow-tooltip="true"
    ></el-table-column>
    ...
</el-table>
<el-pagination
    style="color: #fff"
    v-if="pageshow"
    :current-page.sync="page"
    :page-sizes="[25, 50, 100, 200]"
    :page-size="limit"
    :total="total"
    layout="total, sizes, prev, pager, next, jumper"
    @size-change="pageSizeChangeHandle"
    @current-change="pageCurrentChangeHandle"
></el-pagination>

js:

        (1)先定义data:

data(){
    return:{
        page: 1,
        limit: 50,//分页数
        total: 0,//总数
        sort: "id desc",//默认降序
        pageshow: true,
        protectorList: [],
        scorllTableHeight: window.innerHeight - 220 - 53,
    }
}

        (2)后定义方法:

methods: {
    // 分页, 每页条数
    pageSizeChangeHandle(val) {
      this.page = 1;
      this.limit = val;
      this.pageshow = false;
      this.getProtectorList();
      this.$nextTick(() => {
        this.pageshow = true;
      });
    },
    
    // 分页, 当前页
    pageCurrentChangeHandle(val) {
      this.page = val;
      this.pageshow = false;
      this.getProtectorList();
      this.$nextTick(() => {
        this.pageshow = true;
      });
    },    

    //设置表头行的样式
    tableHeaderColor({ row, column, rowIndex, columnIndex }) {
      return "background-color: #6495ED; color: #fff; text-align:center;";
    },
    
    //设置表格行的样式
    tableColumnStyle({ row, rowIndex }) {
      return "background-color: #fff; color: #000; text-align:center;";
    },

    //排序
    sortChange(column, prop, order) {
        console.log("column",column);
        console.log('prop',prop);
        console.log("order",order)
        // ascending 升序
        this.sort =
            column.order == "ascending"
            ? column.prop + " " + "asc"
            : column.prop + " " + "desc";
        this.getProtectorList();
    },
    
    //查询
    protectorQuerySearch(){
        this.page = 1;
        this.getProtectorList();
    },

    //列表数据
    getProtectorList(){
        let _this = this,queryParams= {},queryUrl = '';
        queryParams['devid'] = _this.dataForm.deviceid;
        queryParams['date'] = _this.dataForm.startTime;
        queryParams['pageNum'] = _this.page;
        queryParams['pageSize'] = _this.limit;
        queryParams['sort'] = _this.sort;//排揎传值
        queryUrl = '/home/protect/data';//并非真实接口
        _this.protectorList = [];
        //qs需要自己去安装,在引入
        _this.$http.post(queryUrl,qs.stringify(queryParams))
            .then(({data: res}) => {
                if(res.code != 0){
                   return _this.$message.error(res.msg);
                }
                if(res.data && res.data.length > 0){
                    let obj = {},data = res.data;//data(res.data)数据结构如下所示
                    for(let item of data){
                        obj = {
                            devShowName: item.devShowName != null ? '--',
                            dbTime: item.dbTime != null ? '--',
                            ...
                        };
                    }
                    _this.protectorList.push(obj);
                }else{
                    _this.$message.warning('查询为空');
                }
            })
            .catch(error=>{
                console.log(error);
            })
    }
}

data(res.data)数据结构如下所示,可以看见前端不需要再去对数据列表降序取值,看时间已经是倒序。

 注意:代码仅供参考,如有不足之处还望评论指出!未达到您的期望还望见谅!

`vue-seamless-scroll` 是一个用于 Vue.js 的库,它能够实现无缝滚动效果,尤其适用于列表数据较多时的场景。而 `el-table` 是 Element UI 组件库的一个表格组件,它提供了丰富的数据展示和操作功能,包括分页。 当你需要在 `vue-seamless-scroll` 使用分页数据时,可以按照以下步骤进行: 1. 首先确保已经在项目安装并引入了 `vue-seamless-scroll` 和 `el-table` 相关组件。 2. 准备你的分页数据,通常这会是一个对象,包含当前页的数据列表 `list`,以及分页相关的属性,如总记录数 `total`、当前页码 `currentPage` 和每页显示数量 `pageSize`。 3. 在模板使用 `el-table` 来展示数据,并且根据分页数据动态设置其 `data` 属性。 4. 使用 `vue-seamless-scroll` 包裹 `el-table` 组件,确保无缝滚动效果应用在表格上。 5. 通过监听分页器的事件来动态更新 `vue-seamless-scroll` 的数据。当分页变化时,你需要更新 `el-table` 所使用的数据列表。 6. 确保 `vue-seamless-scroll` 组件能够正确地接收到数据更新,并且无缝滚动效果得以保持。 示例代码可能如下: ```html <template> <div> <seamless-scroll class="scroll-container" :data="tableData"> <el-table :data="tableData.list"> <!-- 表格列定义 --> <el-table-column prop="field1" label="字段1"></el-table-column> <el-table-column prop="field2" label="字段2"></el-table-column> <!-- ... --> </el-table> </seamless-scroll> <!-- 分页组件 --> <el-pagination layout="total, prev, pager, next" :total="tableData.total" :current-page="tableData.currentPage" :page-sizes="[50, 100, 150]" :page-size="tableData.pageSize" @size-change="handleSizeChange" @current-change="handleCurrentChange" /> </div> </template> <script> import SeamlessScroll from 'vue-seamless-scroll'; export default { components: { SeamlessScroll }, data() { return { // 分页数据 tableData: { list: [], total: 0, currentPage: 1, pageSize: 50 } }; }, methods: { fetchData(page = 1) { // 获取数据的逻辑 // 更新 tableData.list 和其他分页属性 }, handleSizeChange(newSize) { // 分页大小变化时触发 this.tableData.pageSize = newSize; this.fetchData(1); }, handleCurrentChange(newPage) { // 当前页变化时触发 this.fetchData(newPage); } }, mounted() { this.fetchData(); } }; </script> <style> .scroll-container { /* seamless-scroll 容器样式 */ } </style> ``` 在上述代码,我们定义了一个 `vue-seamless-scroll` 组件,并将其作为 `el-table` 的容器。当用户操作分页器时,会触发 `handleSizeChange` 和 `handleCurrentChange` 方法,这些方法会更新 `tableData` 的分页属性,并通过 `fetchData` 方法重新获取数据,以展示新页的内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尔嵘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值