欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

利用vue + element实现表格分页和前端搜索的方法

程序员文章站 2022-05-07 15:01:38
前言 elementui是饿了么前端开源的一个基于vue的前端框架,已经帮我们封装好了一系列功能性的组件,比如栅格系统、表格、表单、树形菜单、通知等。对于搞后台管理界面的...

前言

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>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。