前端现在很火,学的东西也很多,像Vue这个JavaScript神器就挺受欢迎的,用来做单页应用正合适。要说表格,平时工作总要用到它,处理大数据的时候,分页和排序是个难点。那今天,我就教教你如何用Vue巧妙地解决这两个问题!
一、为表格添加分页
分页表单原来超简单!只要装个Vue.js和vuejs-paginate小工具,立马搞定。这个小小的工具真妙,轻轻一点,就能让你的表格马上有分页按钮,真是太神奇了!
npm install vue
搞定vue组件页码超简单!首先,搞个表格来;然后,在里面放几个页码标签就好。这标签里还带了上/下页按钮,别忘了给它们添点料儿,比如当前第几页,怎么翻页,总共有多少页这样的。
npm install vuejs-paginate
搞定!表格现在可以翻页了,想看哪儿的数据随便翻,棒棒哒!
二、为表格添加排序
import Vue from 'vue'; import Paginate from 'vuejs-paginate';
表格数据太多看花眼?别怕,Vue.js有排序功能,查找信息就像吃饭喝水那么简单~这个功能得靠lodash这位JavaScript小能手完成~
首先,你需要装个lodash插件。这是用来给你的表格数据排队序的。先把表格里的所有数据都塞进一堆对象组成的数组;然后再搞个columns数组存上每一列为啥;最后设置个sortOrder对象告诉大家怎么排就行了。
你知道那个叫selectTableSort的小软件?它能帮我们解决搞不清表格数据排序顺序的问题。其实用lodash里的orderBy函数就能轻松完成。用这个函数只需提供三件事:第一个是你要排序的数据范围;第二个就告诉它以哪个字段为基准;最后别忘了,还有一个参数表示是升序还是降序!
记住,别忘了用ID调个sortTableData()方法,这样就能给你的表单按ID排序了哈!
[ { id: 1, name: '第1项' }, { id: 2, name: '第2项' }, { id: 3, name: '第3项' } ]
搞定了!表格现在可以按照需要来排序了,用着方便多了!
三、结语
npm install lodash
今天教大家个小窍门,用Vue.js做表格的分页和排序太简单了!先装上vuejs-paginate这个好帮手,再借助lodash里的orderBy函数就大功告成。不论你是前端高手还是新手,学会这招后,操作起数据和项目会更顺手哦~
npm install --save-dev lodash
只要想学前端,就选Vue.js!这玩意儿再加上各种工具库,让你进步飞快。操作时遇到状况也别怕,工具库就在那儿,随便用就是。
朋友,我特意给你准备了这篇文章帮你轻松入门前端开发!想要更深入地了解的话就直接找我问我会认真解答你的所有疑问滴!
import Vue from 'vue' import _ from 'lodash' export default { name: 'table-component', data () { return { tableData: [ { id: 1, name: "John Doe", age: 32, email: "john.doe@example.com" }, { id: 2, name: "Jane Doe", age: 30, email: "jane.doe@example.com" }, { id: 3, name: "Mark Johnson", age: 25, email: "mark.johnson@example.com" }, { id: 4, name: "Larry Smith", age: 45, email: "larry.smith@example.com" }, { id: 5, name: "Robert Williams", age: 38, email: "robert.williams@example.com" }, { id: 6, name: "David Brown", age: 26, email: "david.brown@example.com" }, { id: 7, name: "Sarah Davis", age: 27, email: "sarah.davis@example.com" }, { id: 8, name: "Julie Robinson", age: 35, email: "julie.robinson@example.com" } ], columns: ['id', 'name', 'age', 'email'], sortOrder: { column: 'id', order: 'asc' } } }, methods: { sortTableData (column) { if (this.sortOrder.column === column) { this.sortOrder.order = this.sortOrder.order === 'asc' ? 'desc' : 'asc' } else { this.sortOrder.column = column this.sortOrder.order = 'asc' } this.tableData = _.orderBy(this.tableData, this.sortOrder.column, this.sortOrder.order) } }, mounted () { this.tableData = _.orderBy(this.tableData, this.sortOrder.column, this.sortOrder.order) } }
评论0