2

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

dunizb 1月2日 发布于前端 blog.dunizb.com

Vue中的混入 mixins 是一种提供分发 Vue 组件中可复用功能的非常灵活的方式。听说在3.0版本中可能会用Hooks的形式实现,但这并不妨碍它的强大。讨论 mixins 如何优化我们的数据列表代码。

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

1月2日 发布,来源:blog.dunizb.com

云南大理崇圣寺

云南大理崇圣寺

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

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

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

list.js

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

const list = {

data () {

return {

loading: false,

pageParam: {

pageNum: 1,

pageSizes: [10, 20, 30, 50],

pageLayout: 'total, sizes, prev, pager, next, jumper',

}

},

methods: {

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 = []

this.loading = false

tempList = apiResult.data

this.pageParam.total = apiResult.page.total

} catch (error) {

reject(error)

}

})

},

* ==> 简单处理 仅仅是对表格处理为空以及取消loading

*/

listExceptionCb (error) {

this.loading = false

console.error(error)

}

},

created () {

this.$nextTick().then(() => {

}

}

export default list

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

import mixin from '@/mixins/list'

import {getList} from '@/api/demo'

export default {

name: 'mixins-demo',

mixins: [mixin],

return {

}

},

methods: {

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

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

646 浏览 6 收藏 报告 阅读模式
载入中...