vue 结合element 表格数据分页 和 搜索

最终效果

组件代码 

    <template>
    <div style="margin-top:50px">
      <el-input v-model="tableDataName" placeholder="请输入姓名" style="width:240px"></el-input>
      <el-button type="primary" @click="doFilter">搜索</el-button>
      <!-- 表格 -->
      <el-table
        :data="tableDataEnd"
        border
        style="width: 100%">
        <el-table-column
          prop="date"
          sortable
          label="日期"
          width="180">
        </el-table-column>
        <el-table-column
          prop="name"
          sortable
          label="姓名"
          width="180">
        </el-table-column>
        <el-table-column
          prop="address"
          sortable
          label="地址">
        </el-table-column>
      </el-table>
      <!-- 分页 -->
      <el-pagination
          @size-change="handleSizeChange"
          @current-change="handleCurrentChange"
          :current-page="currentPage"
          :page-sizes="[1, 2, 3, 4]"
          :page-size="pageSize"
          layout="total, sizes, prev, pager, next, jumper"
          :total="totalItems">
        </el-pagination>
    </div>
    </template>
    
    <script>
    export default {
      data() {
        return {
          tableDataBegin: [
            {
              date: "2016-05-01",
              name: "王小一",
              address: "上海市普陀区金沙江路 1518 弄"
            },
            {
              date: "2016-05-02",
              name: "李小二",
              address: "上海市普陀区金沙江路 1517 弄"
            },
            {
              date: "2016-05-03",
              name: "赵小三",
              address: "上海市普陀区金沙江路 1519 弄"
            },
            {
              date: "2016-05-04",
              name: "陈小四",
              address: "上海市普陀区金沙江路 1516 弄"
            },
            {
              date: "2016-05-05",
              name: "周小五",
              address: "上海市普陀区金沙江路 1518 弄"
            },
            {
              date: "2016-05-06",
              name: "秦小六",
              address: "上海市普陀区金沙江路 1517 弄"
            },
            {
              date: "2016-05-07",
              name: "朱小八",
              address: "上海市普陀区金沙江路 1519 弄"
            },
            {
              date: "2016-05-08",
              name: "张小九",
              address: "上海市普陀区金沙江路 1516 弄"
            }
          ],
          tableDataName: "",
          tableDataEnd: [],
          currentPage: 4,
          pageSize: 4,
          totalItems: 0,
          filterTableDataEnd:[],
          flag:false
        };
      },
      created() {
        //页面初始化时让分页的总条数等于数据的总条数
        this.totalItems = this.tableDataBegin.length;
        //如果分页的页数等于当页要展示的条数
        if (this.totalItems > this.pageSize) {
          for (let index = 0; index < this.pageSize; index++) {
            //那么就将这几条push进展示表格中
            this.tableDataEnd.push(this.tableDataBegin[index]);
          }
        } else {
          //否则就展示首页
          this.tableDataEnd = this.tableDataBegin;
        }
      },
      methods: {
        //前端搜索功能需要区分是否检索,因为对应的字段的索引不同
        //用两个变量接收currentChangePage函数的参数
        doFilter() {
          if (this.tableDataName == "") {
            this.$message.warning("查询条件不能为空!");
            return;
          }
          this.tableDataEnd = []
          //每次手动将数据置空,因为会出现多次点击搜索情况
          this.filterTableDataEnd=[]
          this.tableDataBegin.forEach((value, index) => {
            if(value.name){
              if(value.name.indexOf(this.tableDataName)>=0){
                this.filterTableDataEnd.push(value)
              }
            }
          });
          //页面数据改变重新统计数据数量和当前页
          this.currentPage=1
          this.totalItems=this.filterTableDataEnd.length
          //渲染表格,根据值
          this.currentChangePage(this.filterTableDataEnd)
          //页面初始化数据需要判断是否检索过
          this.flag=true
        },   
        //每页展示条数
          handleSizeChange(val) {
          console.log(`每页 ${val} 条`);
          this.pageSize = val;
          this.handleCurrentChange(1);
},


      handleCurrentChange(val) {
        console.log(`当前页: ${val}`);
        this.currentPage = val;
        //需要判断是否检索
        if (!this.flag) {
          this.currentChangePage(this.tableDataBegin);
          console.log(this.tableDataEnd);
        } else {
          this.currentChangePage(this.filterTableDataEnd);
          console.log(this.tableDataEnd);
        }
      },//组件自带监控当前页码

      //点击下一页
      currentChangePage(list) {
        let from = (this.currentPage - 1) * this.pageSize;
        let to = this.currentPage * this.pageSize;
        this.tableDataEnd = [];
        for (; from < to; from++) {
          if (list[from]) {
              this.tableDataEnd.push(list[from]);
          }
        }
      }
    }
  };
 </script>

 

  • 1
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值