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

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

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

list.js


  1. const list = {
  2. data () {
  3. return {
  4. loading: false,
  5. pageParam: {
  6. pageNum: 1, // 页码
  7. pageSize: 20, // 页长
  8. total: 0 // 总记录数数
  9. },
  10. pageSizes: [10, 20, 30, 50], // 页长数
  11. pageLayout: 'total, sizes, prev, pager, next, jumper', // 分页布局
  12. pageCount: 5, // 页码按钮的数量,当总页数超过该值时会折叠(大于等于 5 且小于等于 21 的奇数)
  13. list: []
  14. }
  15. },
  16. methods: {
  17. // 分页回掉事件
  18. handleSizeChange (val) {
  19. this.pageParam.pageSize = val
  20. this.getList()
  21. },
  22. handleCurrentChange (val) {
  23. this.pageParam.pageNum = val
  24. this.getList()
  25. },
  26. /**
  27. * 表格数据请求成功的回调 处理完公共的部分(分页,loading取消)之后把控制权交给页面
  28. * @param {*} apiResult
  29. * @returns {*} promise
  30. */
  31. listSuccessCb (apiResult = {}) {
  32. return new Promise((resolve, reject) => {
  33. let tempList = [] // 临时list
  34. try {
  35. this.loading = false
  36. tempList = apiResult.data
  37. this.pageParam.total = apiResult.page.total
  38. // 直接抛出
  39. resolve(tempList)
  40. } catch (error) {
  41. reject(error)
  42. }
  43. })
  44. },
  45. /**
  46. * 处理异常情况
  47. * ==> 简单处理 仅仅是对表格处理为空以及取消loading
  48. */
  49. listExceptionCb (error) {
  50. this.loading = false
  51. console.error(error)
  52. }
  53. },
  54. created () {
  55. // 这个生命周期是在使用组件的生命周期之前
  56. this.$nextTick().then(() => {
  57. // todo
  58. })
  59. }
  60. }
  61. export default list

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


  1. import mixin from '@/mixins/list' // 引入
  2. import {getList} from '@/api/demo'
  3. export default {
  4. name: 'mixins-demo',
  5. mixins: [mixin], // 使用mixins
  6. data () {
  7. return {
  8. }
  9. },
  10. methods: {
  11. // 加载列表
  12. getList () {
  13. const params = { ...this.searchForm, ...this.pageParam }
  14. fetchUserList(params).then(res => {
  15. if (res.code === 0) {
  16. this.listSuccessCb(res).then((list) => {
  17. this.list = list
  18. }).catch((err) => {
  19. console.log(err)
  20. })
  21. }
  22. })
  23. },
  24. },
  25. created() {
  26. this.load()
  27. }
  28. }

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

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

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

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

来源:https://segmentfault.com/a/1190000017716554

小技巧|使用Vue.js的Mixins复用你的代码的更多相关文章

  1. 清明小长假之VUE.JS学习测试码

    我们放了四天假,刚好借此机会,系统的了解一下VUE.JS. <!DOCTYPE html> <html> <head> <meta charset=" ...

  2. 微信小程序与Vue js数据渲染对比

    //小程序 Page({ data: { items: [] }, onLoad: function(options) { this.setData({ items: [1,2,3] }) } }) ...

  3. Vue.js起手式+Vue小作品实战

    本文是小羊根据Vue.js文档进行解读的第一篇文章,主要内容涵盖Vue.js的基础部分的知识的,文章顺序基本按照官方文档的顺序,每个知识点现附上代码,然后根据代码给予个人的一些理解,最后还放上在线编辑 ...

  4. 用Vue.js开发微信小程序:开源框架mpvue解析

    前言 mpvue 是一款使用 Vue.js 开发微信小程序的前端框架.使用此框架,开发者将得到完整的 Vue.js 开发体验,同时为 H5 和小程序提供了代码复用的能力.如果想将 H5 项目改造为小程 ...

  5. VUE.JS和小程序的共通之处

    我是先学习的小程序开发,之后才了解到vue.js.也是一直没有时间去看相关vue.js的知识和内容.现在回顾起来,小程序和vue.js都是前端的内容. 例如小程序中的目录结构物page+app.js+ ...

  6. vue.js之组件篇

    Vue.js 组件 模块化:是从代码逻辑的角度进行划分的: 组件化:是从UI界面的角度进行划分的. 组件(Component)是 Vue.js 最强大的功能之一,组件可以扩展 HTML 元素,封装可重 ...

  7. vue.js 实战 todo list

    vue.js 起源 vue.js 的作者是尤雨溪,是一名中国人,之前在谷歌工作,现在在全职维护 vue 项目. vue.js 是 2014 年推出来的.现在已经更新到 2.x 版本,3.0 版本会在 ...

  8. Vue.js简单的应用

    1:一个简单实现 下面代码部分: <body> <div id="myDiv1"> {{userName}} </div> </body& ...

  9. 微信小程序开发小技巧:

    小技巧:输入view.tabs_content就可以生成下面的代码. 输入p10,就可以得到: 输入jc:c得到:文字水平对齐 输入d:f得到: 输入ai:c得到: 输入bb得到: currentCo ...

随机推荐

  1. html input size maxlength

    最近做项目用到input的size和maxlength属性,以前只顾用没有用心去看看这2个标签的区别,今天周末baidu了一下,有所理解.特记录于此!   <p>Name: <inp ...

  2. VSCode调试配置

    http://code.visualstudio.com/docs/editor/debugging#_launch-configurations VSCode内置Node.js运行时, 能调试jav ...

  3. Toxophily-数论以及二分三分

    G - Toxophily Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submi ...

  4. redis问题集

    Redis有哪些数据结构? 字符串String.字典Hash.列表List.集合Set.有序集合SortedSet. 如果你是Redis中高级用户,还需要加上下面几种数据结构HyperLogLog.G ...

  5. [LintCode] 全排列

    递归实现: class Solution { public: /** * @param nums: A list of integers. * @return: A list of permutati ...

  6. slenium截屏

    创建全屏截屏: public static byte[] takeScreenshot(WebDriver driver) throws IOException { WebDriver augment ...

  7. mysql delete 多表

    DELETE u.*,acu.*,alu.* FROM user u, accountuser acu ,algouser alu WHERE u.userId=11 and acu.userID=1 ...

  8. 转!java产生不重复随机数

    private static void testC(int sz) { long startTime = System.currentTimeMillis(); //开始测试时间 Random rd ...

  9. pip 查看已安装模块、卸载指定模块、安装指定版本模块

    操作背景 最近使用 pandas+numpy+plotly 画heatmap(热力图),来处理股票数据,语法.步骤都没问题,但到画图那一步老是报错,且 plotly 版本为3.1.0: 最后找到原因, ...

  10. 搜狐云景client工具评測之WordPress的搭建

    搜狐云景是搜狐推出的一款PaaS产品,眼下还处在公測阶段,拿到邀请码后试用了一下,感觉还不错. 搜狐云景提供了四种方式部署应用,感觉应该能够满足各种口味的码农:1. zip包的形式在网页上传并部署   ...