vue mixins组件复用的几种方式(小结)

网友投稿 240 2023-04-08


vue mixins组件复用的几种方式(小结)

最近在做项目的时候,研究了mixins,此功能有妙处。用的时候有这样一个场景,页面的风格不同,但是执行的方法,和需要的数据非常的相似。我们是否要写两种组件呢?还是保留一个并且然后另个一并兼容另一个呢?

不管以上那种方式都不是很合理,因为组件写成2个,不仅麻烦而且维护麻烦;第二种虽然做了兼容但是页面逻辑造成混乱,必然不清晰;有没有好的方法,有那就是用vue的混合插件mixins。混合在Vue是为了提出相似的数据和功能,使代码易懂,简单、清晰。

1.场景

假设我们有几个不同的组件,它们的工作是切换状态布尔、模态和工具提示。这些提示和情态动词不有很多共同点,除了功能:他们看起来不一样,他们不习惯相同,但逻辑是相同的。

//弹框

const Modal = {

template: '#modal',

data() {

return {

isShowing: false

}

},

methods: {

toggleShow() {

this.isShowing = !this.isShowing;

}

},

components: {

appChild: Child

}

}

//提示框

const Tooltip = {

template: '#tooltip',

data() {

return {

isShowing: false

}

},

methods: {

toggleShow() {

this.isShowing = !this.isShowing;

}

},

components: {

appChild: Child

}

}

上面是一个弹框和提示框,如果考虑做2个组件,或者一个兼容另一个都不是合理方式。请看一下代码

const toggle = {

data() {

return {

isShowing: false

}

},

methods: {

tohttp://ggleShow() {

this.isShowing = !this.isShowing;

}

}

}

const Modal = {

template: '#modal',

mixins: [toggle],

components: {

appChild: Child

}

};

const Tooltip = {

template: '#tooltip',

mixins: [toggle],

components: {

appChild: Child

}

};

用mixins引入toggle功能相似的js文件,进行混合使用

2.可以合并生命周期

//mixin

const hi = {

mounted() {

console.log('this mixin!')

}

}

//vue组件

new Vue({

el: '#app',

mixins: [hi],

mounted() {

console.log('this Vue instance!')

}

});

//Output in console

> this mixin!

> this Vue instance!

先输出的是mixins的数据

3、可以全局混合(类似已filter)

Vue.mixin({

mounted() {

console.log('hello from mixin!')

},

method:{

test:function(){

}

}

})

new Vue({

el: '#app',

mountedhttp://() {

console.log('this Vue instance!')

}

})

会在每一个组件中答应周期中的log,同时里面的方法,类似于vue的prototype添加实例方法一样。

var install = function (Vue, options) {

// 1. 添加全局方法或属性

Vue.myGlobalMethod = function () {

// 逻辑...

}

// 2. 添加全局资源

Vue.directive('my-directive', {

bind (el, binding, vnode, oldVnode) {

// 逻辑...

}

...

})

// 3. 注入组件

Vue.mixin({

created: function () {

// 逻辑...

}

...

})

// 4. 添加实例方法

Vue.prototype.$myMethod = function (options) {

// 逻辑...

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:JDBC中使用Java8的日期LocalDate和LocalDateTime操作mysql、postgresql
下一篇:spring Data jpa简介_动力节点Java学院整理
相关文章

 发表评论

暂时没有评论,来抢沙发吧~