vue mixins组件复用的几种方式(小结)
最近在做项目的时候,研究了mixins,此功能有妙处。用的时候有这样一个场景,页面的风格不同,但是执行的方法,和需要的数据非常的相似。我们是否要写两种组件呢?还是保留一个并且然后另个一并兼容另一个呢?
不管以上那种方式都不是很合理,因为组件写成2个,不仅麻烦而且维护麻烦;第二种虽然做了兼容但是页面逻辑造成混乱,必然不清晰;有没有好的方法,有那就是用vue的混合插件mixins。混合在Vue是为了提出相似的数据和功能,使代码易懂,简单、清晰。
1.场景
假设我们有几个不同的组件,它们的工作是切换状态布尔、模态和工具提示。这些提示和情态动词不有很多共同点,除了功能:他们看起来不一样,他们不习惯相同,但逻辑是相同的。
//弹框
constModal={
template:'#modal',
data(){
return{
isShowing:false
}
},
methods:{
toggleShow(){
this.isShowing=!this.isShowing;
}
},
components:{
appChild:Child
}
}
//提示框
constTooltip={
template:'#tooltip',
data(){
return{
isShowing:false
}
},
methods:{
toggleShow(){
this.isShowing=!this.isShowing;
}
},
components:{
appChild:Child
}
}
上面是一个弹框和提示框,如果考虑做2个组件,或者一个兼容另一个都不是合理方式。请看一下代码
consttoggle={
data(){
return{
isShowing:false
}
},
methods:{
toggleShow(){
this.isShowing=!this.isShowing;
}
}
}
constModal={
template:'#modal',
mixins:[toggle],
components:{
appChild:Child
}
};
constTooltip={
template:'#tooltip',
mixins:[toggle],
components:{
appChild:Child
}
};
用mixins引入toggle功能相似的js文件,进行混合使用
2.可以合并生命周期
//mixin
consthi={
mounted(){
console.log('thismixin!')
}
}
//vue组件
newVue({
el:'#app',
mixins:[hi],
mounted(){
console.log('thisVueinstance!')
}
});
//Outputinconsole
>thismixin!
>thisVueinstance!
先输出的是mixins的数据
3、可以全局混合(类似已filter)
Vue.mixin({
mounted(){
console.log('hellofrommixin!')
},
method:{
test:function(){
}
}
})
newVue({
el:'#app',
mounted(){
console.log('thisVueinstance!')
}
})
会在每一个组件中答应周期中的log,同时里面的方法,类似于vue的prototype添加实例方法一样。
varinstall=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){
//逻辑...
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。