Vue.js组件如何混合和自定义指令-创新互联
这篇文章将为大家详细讲解有关Vue.js组件如何混合和自定义指令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名与空间、网站空间、营销软件、网站建设、新都网站维护、网站推广。混合是什么
混合 (mixins) 是一种分发 Vue 组件中可复用功能的非常灵活的方式。混合对象可以包含任意组件选项。以组件使用混合对象时,所有混合对象的选项将被混入该组件本身的选项。
例如:
var tpl1={ template:'#stpl1', data:function(){ return {msg:false} }, methods:{ msgf:function(){ this.msg=!this.msg } } } var tpl2={ template:'#stpl2', data:function(){ return {msg:false} }, methods:{ show:function(){ this.msg=true }, hide:function(){ this.msg=false } } } new Vue({ el:'#box', components:{ tpla:tpl1, tplb:tpl2, } })
我们会发现,两个组件中的数据大多数相同,这是我们可以将它们进行混合
// 首先,定义一个混合对象 var mymixin = { data:function(){ return {msg:false} }, methods:{ show:function(){ this.msg=true }, hide:function(){ this.msg=false }, msgf:function(){ this.msg=!this.msg } } } var tpl1={ template:'#stpl1', minins:[mymixin] } var tpl2={ template:'#stpl2', minins:[mymixin] } // 如果我们需要在第一个组件定义data为true时,我们可以直接在组件内定义,他会覆盖mixin的data var tpl1={ template:'#stpl1', minins:[mymixin], data:function(){ msg:true } }
自定义指令
除了默认设置的核心指令( v-model 和 v-show ),Vue 也允许注册自定义指令。注意,在 Vue2.0 里面,代码复用的主要形式和抽象是组件——然而,有的情况下,你仍然需要对纯 DOM 元素进行底层操作,这时候就会用到自定义指令。
// 注册一个全局自定义指令 v-focus Vue.directive('focus', { // 当绑定元素插入到 DOM 中。 inserted: function (el) { // 聚焦元素 el.focus() } })
也可以注册局部指令,组件中接受一个 directives 的选项:
directives: { focus: { // 指令的定义--- } }
然后你可以在模板中任何元素上使用新的 v-focus 属性:
关于“Vue.js组件如何混合和自定义指令”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
新闻名称:Vue.js组件如何混合和自定义指令-创新互联
网页路径:http://pwwzsj.com/article/csesjg.html