未加星标

小技巧|使用Vue.js的Mixins复用你的代码

字体大小 | |
[前端(javascript) 所属分类 前端(javascript) | 发布者 店小二05 | 时间 2019 | 作者 红领巾 ] 0人收藏点击收藏

小技巧|使用Vue.js的Mixins复用你的代码

云南大理崇圣寺

Vue中的混入 mixins 是一种提供分发 Vue 组件中可复用功能的非常灵活的方式。听说在3.0版本中可能会用Hooks的形式实现,但这并不妨碍它的强大。基础部分的可以看这里。

这里主要来讨论 mixins 如何优化我们的数据列表代码。

如果我们有大量的表格页面,仔细一扒拉你发现非常多的东西都是可以复用的例如分页,表格高度,加载方法, laoding 声明等一大堆的东西。下面我们来整理出来一个简单通用混入 list.js

list.js

const list = { data () { return { loading: false, pageParam: { pageNum: 1, // 页码 pageSize: 20, // 页长 total: 0 // 总记录数数 }, pageSizes: [10, 20, 30, 50], // 页长数 pageLayout: 'total, sizes, prev, pager, next, jumper', // 分页布局 pageCount: 5, // 页码按钮的数量,当总页数超过该值时会折叠(大于等于 5 且小于等于 21 的奇数) list: [] } }, methods: { // 分页回掉事件 handleSizeChange (val) { this.pageParam.pageSize = val this.getList() }, handleCurrentChange (val) { this.pageParam.pageNum = val this.getList() }, /** * 表格数据请求成功的回调 处理完公共的部分(分页,loading取消)之后把控制权交给页面 * @param {*} apiResult * @returns {*} promise */ listSuccessCb (apiResult = {}) { return new Promise((resolve, reject) => { let tempList = [] // 临时list try { this.loading = false tempList = apiResult.data this.pageParam.total = apiResult.page.total // 直接抛出 resolve(tempList) } catch (error) { reject(error) } }) }, /** * 处理异常情况 * ==> 简单处理 仅仅是对表格处理为空以及取消loading */ listExceptionCb (error) { this.loading = false console.error(error) } }, created () { // 这个生命周期是在使用组件的生命周期之前 this.$nextTick().then(()=> { // todo }) } } export default list

下面我们直接在组件中使用这个 mixins

import mixin from '@/mixins/list' // 引入 import {getList} from '@/api/demo' export default { name: 'mixins-demo', mixins: [mixin], // 使用mixins data () { return { } }, methods: { // 加载列表 getList () { const params = { ...this.searchForm, ...this.pageParam } fetchUserList(params).then(res=> { if (res.code === 0) { this.listSuccessCb(res).then((list) => { this.list = list }).catch((err) => { console.log(err) }) } }) }, }, created() { this.load() } }

使用了 mixins 之后一个简单的有 loadoing, 分页,数据的表格大概就只需要上面这些代码。

在 list.js 中我们可以直接调用组件的方法,比如在分页回调事件中调用组件的 getList() 方法,在组件中直接调用 list.js 中的代码,如直接访问 this.pageParam 。

当组件和 mixins 对象含有同名选项时,这些选项将以恰当的方式混合。比如,数据对象在内部会进行 浅合并 (一层属性深度),在和组件的数据发生冲突时以组件数据优先。

你学会了吗?还不快试试。。。

本文前端(javascript)相关术语:javascript是什么意思 javascript下载 javascript权威指南 javascript基础教程 javascript 正则表达式 javascript设计模式 javascript高级程序设计 精通javascript javascript教程

代码区博客精选文章
分页:12
转载请注明
本文标题:小技巧|使用Vue.js的Mixins复用你的代码
本站链接:https://www.codesec.net/view/627864.html


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 前端(javascript) | 评论(0) | 阅读(86)