zoukankan      html  css  js  c++  java
  • 小技巧|使用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 对象含有同名选项时,这些选项将以恰当的方式混合。比如,数据对象在内部会进行浅合并 (一层属性深度),在和组件的数据发生冲突时以组件数据优先。

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

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

  • 相关阅读:
    Ubuntu中安装XAMPP出错的解决方法
    sudo 后不用输入密码的配置
    javascript鼠标双击时触发事件大全
    PHP空值判断
    40音乐海报的创意例子
    35个令人印象深刻的创意404错误页面设计
    35个高分辨率创意苹果桌面壁纸
    38惊人的HD(高清晰度)壁纸七彩的例子
    25精心设计的联系页面例子
    pgpoolII中对 setsockopt 的利用
  • 原文地址:https://www.cnblogs.com/qixidi/p/10224794.html
Copyright © 2011-2022 走看看