| 
                          
短视频,自媒体,达人种草一站服务
 
这篇文章主要为大家详细介绍了vue+iview分页组件的封装,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 
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组件学习教程进行学习。                         (编辑:91站长网) 
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! 
                     |