国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

利用vue + element實現表格分頁和前端搜索的方法

2019-11-19 14:39:23
字體:
來源:轉載
供稿:網友

前言

ElementUI是餓了么前端開源的一個基于Vue的前端框架,已經幫我們封裝好了一系列功能性的組件,比如柵格系統、表格、表單、樹形菜單、通知等。對于搞后臺管理界面的項目,特別是不需要考慮兼容ie8、ie9以下的項目、ElementUI是一個不錯的選擇。

而且ElementUI的文檔寫得十分詳盡,參照demo可以很快上手。

本文主要介紹了關于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(this.currentPage); }, handleCurrentChange(val) {  console.log(`當前頁: ${val}`);  this.currentPage = val;  //需要判斷是否檢索  if(!this.flag){  this.currentChangePage(this.tableDataEnd)  }else{  this.currentChangePage(this.filterTableDataEnd)    } }, //組件自帶監控當前頁碼 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>

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广元市| 无为县| 徐汇区| 盖州市| 凤城市| 巴林右旗| 喜德县| 龙游县| 北安市| 和田县| 恩平市| 和顺县| 彭山县| 晋宁县| 上林县| 沙河市| 巧家县| 利川市| 靖宇县| 金阳县| 晋城| 泰顺县| 关岭| 铁力市| 湖口县| 谷城县| 锦屏县| 太保市| 通渭县| 三亚市| 连平县| 蒙阴县| 蚌埠市| 甘洛县| 定结县| 浙江省| 义乌市| 朝阳县| 浮山县| 玉田县| 荔波县|