vue+element的表格分頁和前端搜索

1.前端後臺管理會存在不少表格,表格數據過多就須要分頁;
2.前端交互每次搜索若是都請求服務器會加大服務器的壓力,因此在數據量不是很大的狀況下能夠一次性將數據返回,前端作檢索
3.下面貼上一個demo前端


<template>
    <div>
      <el-input v-model="tableDataName" placeholder="請輸入姓名" style="width:240px"></el-input>
      <el-button type="primary" @click="doFilter">搜索</el-button>
      <el-button type="primary" @click="openData">展現數據</el-button>
      <el-table
        :data="tableDataEnd"
        border
        style="width: 100%">
        <el-table-column
          prop="date"
          label="日期"
          width="180">
        </el-table-column>
        <el-table-column
          prop="name"
          label="姓名"
          width="180">
        </el-table-column>
        <el-table-column
          prop="address"
          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: 2,
          totalItems: 0,
          filterTableDataEnd:[],
          flag:false
        };
      },
      created() {
        this.totalItems = this.tableDataBegin.length;
        if (this.totalItems > this.pageSize) {
          for (let index = 0; index < this.pageSize; index++) {
            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
        },
        openData() {},
        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>
相關文章
相關標籤/搜索