时间:2021-05-26
vue+iview的分页组件封装
1.在components中创建pagination文件夹,接着创建src,index.js,index.less文件
2.index.less文件
//需要修改的样式.ivu-page-options { margin-left: 10px; .ivu-page-options-sizer { margin-right: 0; } }3.index.js文件
import "./index.less";import component from "./src/main";component.install = function (Vue) { Vue.component(component.name, component);};export default component;4.src文件夹中的main.vue
<template> <!-- 分页组件 --> <Page class="saas-pagination" ref="page" :loading="loading" :disabled="disabled" :total="total" :show-sizer="sizer" :show-elevator="elevator" :current="params.page" :page-size="params.rows" :page-size-opts="sizeOpts" @on-change="currentChange" @on-page-size-change="pageChange"/></template><script>export default { props: { loading: { type: Boolean, default: false }, total: { // 数据总数 type: [String, Number], default: 0 }, page: { // 当前分页 type: [String, Number], default: 1 }, rows: { // 每页显示多少条 type: [String, Number], default: 10 }, disabled: { type: Boolean, default: false }, sizer: { // 是否显示下拉组件 type: Boolean, default: false }, elevator: { // 是否显示跳转输入框 type: Boolean, default: false } }, watch: { page (to) { this.params.page = to; }, rows (to) { this.params.rows = to; } }, data () { return { sizeOpts: [10, 20, 30, 40, 50, 60, 70, 80, 90, 100], params: { page: 1, rows: 10 } } }, methods: { // 分页改变 currentChange (current) { this.params.page = current; this.onChange(); }, // 每页显示条数改变 pageChange (rows) { this.params.page = 1; this.params.rows = rows; this.onChange(); }, onChange () { this.$emit("on-change", JSON.parse(JSON.stringify(this.params))); }, reset () { this.params = { page: 1, rows: 10 } this.onChange(); // 当前页码还原 // this.$refs.page.currentPage = 1; } }}</script>5.在components中创建index.js,用于全局引入
import GlobalPage from "@/components/pagination/index.js";export default (Vue) => { Vue.component("GlobalPage ", GlobalPage );}6然后在全局的main.js引入,可全局使用
import components from "@/components/index.js";Vue.use(components)7.组件的使用
<template> <div> <global-page ref="pagination" :sizer="true" :page="formData.page" :rows="formData.rows" :total="total" @on-change="pageChange"> </global-page> </div></template><script>export default { data(){ return { total: 0, // 数据总数 queryForm:{}, formData: { page: 1, rows: 10, } } }, methods: { // 分页切换 pageChange (params) { this.queryForm.page = params.page this.queryForm.rows = params.rows //查询数据的方法 this.search(this.queryForm) }, }}</script>关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
vue+iview使用树形控件1.开发环境vue+iview2.电脑系统windows10专业版3.在使用vue+iview开发的过程中,我们经常会使用ivie
vue+iview分页及删、查功能实现,供大家参考,具体内容如下首先要想实现分页功能必须得知道当前页码、每页大小、总数目。iview对分页的功能支持还是很强大的
本文实例讲述了Vue开发之封装分页组件与使用。分享给大家供大家参考,具体如下:使用elementui中的el-pagination来封装分页组件paginati
引言:最近使用vue在做一个后台系统,技术栈vue+iView,在页面中生成表格后,iView可以实现表格的导出,不过只能导出csv格式的,并不适合项目需求。如
本文实例为大家分享了vue+iview动态渲染表格(iview插件table),供大家参考,具体内容如下效果图(表格头部和表格主体都是动态渲染)重要代码expo