vue+iview分页组件的封装
程序员文章站
2022-04-12 23:33:43
vue+iview的分页组件封装1.在components中创建pagination文件夹,接着创建src,index.js,index.less文件2.index.less文件//需要修改的样式.i...
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"; /* istanbul ignore next */ 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组件学习教程进行学习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。