ホームページ  >  記事  >  ウェブフロントエンド  >  vue + 要素でテーブルページングを実装する方法

vue + 要素でテーブルページングを実装する方法

亚连
亚连オリジナル
2018-06-15 16:24:051823ブラウズ

ご存知のとおり、Element は Vue.js バックエンド コンポーネント ライブラリのセットであり、バックエンド プロジェクトをより簡単かつ迅速に開発するのに役立ちます。以下の記事では、vue + 要素を使用してテーブル ページングとフロントエンド検索を実装するための関連情報を主に紹介します。必要な方は一緒に参照してください。

前書き

ElementUI は、Ele.me によってオープンソース化されている Vue ベースのフロントエンド フレームワークで、グリッド システム、テーブル、フォーム、ツリー メニュー、通知などの一連の機能コンポーネントをカプセル化するのに役立ちます。等バックエンド管理インターフェイスに関与するプロジェクト、特に以下の ie8 または ie9 との互換性を必要としないプロジェクトの場合、ElementUI は良い選択です。

そして、ElementUI のドキュメントは非常に詳しく説明されており、デモを参照することですぐに始めることができます。

この記事では、テーブル ページングとフロントエンド検索を実装するための Vue + 要素に関する関連コンテンツを主に紹介します。以下では多くを述べませんが、詳細な紹介を見てみましょう。

実装のアイデア

1. フロントエンドとバックエンドの管理には多くのテーブルがあり、テーブルデータが多すぎる場合はページングが必要になります。

2.それぞれの検索とやり取りしてサーバーにリクエストすると、サーバーへの負荷が増大するため、データ量がそれほど大きくない場合は、一度にデータを返してフロントエンドで取得を行うことができます

3.はデモです

サンプルコードです​​

<template>
<p>
 <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>
</p>
</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>

上記は私が皆さんに役立つようにまとめたものです。

関連記事:

Vue.set() を使用してデータへの動的応答を実現する方法

vue で画像とデータを動的にバインドする方法画像パスを返す

vue で静的画像を動的に変更する方法そして、ネットワーク画像をリクエストします

AngularでブラウザプラグインBatarangを使用する方法

vueでプリロードウォッチの使用方法を

JSでオフセットと均一アニメーションを実装する方法

ペーストボードを実装する方法JSのコピー機能を使う

HTMLをPDFに変換する機能をJSで実装する方法

以上がvue + 要素でテーブルページングを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。