vue mixin 以-后台管理系统分页功能为例,mixin的最佳实现

写在前面


作者简书地址
vue mixin在实战项目中的典型妙用,所举例项目是基于vue全家桶(vue-router+vuex+axios+element-ui)的后台管理系统,需要一些有vue项目开发经验的读者阅读。
一般来说呢,管理的数据很多是列表数据,列表数据就常会出现分页功能,而分页功能基本上在以下情况中会调用列表接口

  • 页面初始化
  • 查询的按钮
  • 分页的页码改变
  • 分页的长度改变

本文章所分享的基于vue的mixin(代码混入)在实际项目中如何减少代码量,让我们的分页功能简洁高效,不需要在每个页面中写重复的代码

具体步骤:

一、 首先在src下创建mixin文件夹 (其可书写的格式与.vue文件中的script部分)


D949A92E5DCF6E682D1ED6E2A7A3AA31.jpg

二、将其全局混入到main.js

import mixin from './mixin/index'
Vue.mixin(mixin)

三、在mixin.js中定义两个变量


30504C59419BDAFB356B0B0C12161A0D.jpg

queryParams:{} =>主要用来存放列表接口的查询条件的参数
PAGINATION: {
pageSize: 20,
currentPage: 1,
total: 0
},=》是element-ui中分页组件( el-pagination)的初始化参数

四、mixin 中的methods定义好触发分页的事件方法

//查询按钮
check() { 
      this.PAGINATION = {
        ...this.PAGINATION,
        currentPage: 1
      }
      this.queryParams = this.getParams()
      this.useMethod()
    },
// 分页长度改变
    handleSizeChange(pageSize) {     
     this.PAGINATION = {
        ...this.PAGINATION,
        pageSize
      }
      this.queryParams = {
        ...this.queryParams,
        offset: this.PAGINATION.pageSize
      }
      this.useMethod()
    },
//分页页码改变
    handleCurrentChange(currentPage) { 
      this.PAGINATION = {
        ...this.PAGINATION,
        currentPage
      }
      this.queryParams = {
        ...this.queryParams,
        page: this.PAGINATION.currentPage
      }
      this.useMethod()
    },

上面的this.useMethod()是我们mixin处理分页功能的核心

五、使用this.useMethod()方法让我们调用不同的分页接口

useMethod() {
      switch (this.method) {
        case 'searchUserListByPage'://用户列表
          this.searchUserListByPage()
          break
        case 'getAdminListByPage'://管理列表
          this.getAdminListByPage()
          break
        case 'getServiceOrderListByPage':  //订单列表
          this.getServiceOrderListByPage()
          break
      }
      //使用 this[this.method]() 可以替换掉switch循环 推荐这样使用

this.method从何而来呢?
=》来自我们所需要分页功能的vue文件中,表示的是列表方法
题外话:this.userMethod()与this.method是可以省略的,这个各位看官自己去发现吧。由于省略的话与本人尊崇的代码风格不一致,就没去掉了。
补一句(当你这里的case越多你也会感到这个方案的魅力)
还是使用 推荐方法吧


回到我们所需要分页的具体vue文件中:

在这里我们应该写些什么呢?
一、定义一个名为(method)的参数 规则如下


120CFBB67025AC6D8ED47E01B98A17C9.jpg

尽量与我们的列表方法名称保持一致,增加可读性

二、列表方法的参数获取

 getParams() {
      let startTime = ''
      let endTime = ''
      if (this.rangeTime && this.rangeTime.length > 0) {
        startTime = this.rangeTime[0].valueOf() / 1000
        endTime = (this.rangeTime[1].valueOf() + this.dayMs) / 1000
      }
      return {
        keyword: this.keyword,
        state: this.state,
        page: this.PAGINATION.currentPage,
        offset: this.PAGINATION.pageSize,
        startTime: startTime,
        endTime: endTime
      }
    },
    async searchUserListByPage() {
      this.loading = true
      let res = await searchUserListByPage({ ...this.queryParams })
      this.tableData = res.body.list
      this.PAGINATION.total = res.body.total
      this.loading = false
    },

为何里面传参不是 let res = await searchUserListByPage({ ...this.getParams() })
具体参考《具体步骤》中的 三 、和 四、
页面初始化只需要在 created 阶段 调用 this.check()
具体参考《具体步骤》中的 四、 和 五、Ï

created() {
    this.check()
  },

写在后面

这是本人第一次发表文章,有不懂的同学可以探讨探讨。后续还会发表一篇关于axios的二次封装以及在实际项目中各种请求(get,post,delete....)的统一传参,各类接口统一代码风格。
简书首发网址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 161,780评论 4 369
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,424评论 1 305
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,397评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,576评论 0 218
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,997评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,945评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,107评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,850评论 0 208
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,625评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,804评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,285评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,613评论 3 261
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,291评论 3 242
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,164评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,963评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,096评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,886评论 2 278

推荐阅读更多精彩内容