全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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: {
  toggleShow() {
   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',
 mounted() {
  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) {
  // 逻辑...
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# vue  # mixins组件复用  # mixins组件  # Vue中的混入的使用(vue mixins)  # 在Vue.js中使用Mixins的方法  # Vue之Mixins(混入)的使用方法  # 详解Vue.js Mixins 混入使用  # vue中混入mixins的使用方法  # vue的mixins属性详解  # 深入了解Vue.js 混入(mixins)  # Vue中mixins的使用方法以及实际项目应用指南  # 的是  # 是一个  # 有很多  # 两种  # 不是很  # 会在  # 这样一个  # 布尔  # 有几个  # 类似于  # 不习惯  # 第二种  # 大家多多  # 要写  # 是为了  # 那就是  # 模态  # modal  # data  # template 


相关文章: 如何用PHP工具快速搭建高效网站?  高端网站建设与定制开发一站式解决方案 中企动力  外贸公司网站制作哪家好,maersk船公司官网?  网站建设设计制作营销公司南阳,如何策划设计和建设网站?  小型网站建站如何选择虚拟主机?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  ,怎么在广州志愿者网站注册?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  C#如何使用XPathNavigator高效查询XML  如何快速生成可下载的建站源码工具?  如何通过虚拟主机空间快速建站?  青岛网站建设如何选择本地服务器?  佛山企业网站制作公司有哪些,沟通100网上服务官网?  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  如何解决VPS建站LNMP环境配置常见问题?  潮流网站制作头像软件下载,适合母子的网名有哪些?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  建站10G流量真的够用吗?如何应对访问高峰?  网站企业制作流程,用什么语言做企业网站比较好?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  建站之星导航如何优化提升用户体验?  宿州网站制作公司兴策,安徽省低保查询网站?  建站主机解析:虚拟主机配置与服务器选择指南  Swift中循环语句中的转移语句 break 和 continue  Python如何创建带属性的XML节点  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  宁波自助建站系统如何快速打造专业企业网站?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  深圳网站制作案例,网页的相关名词有哪些?  如何用IIS7快速搭建并优化网站站点?  b2c电商网站制作流程,b2c水平综合的电商平台?  c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在阿里云ECS服务器部署织梦CMS网站?  如何通过西部数码建站助手快速创建专业网站?  香港服务器如何优化才能显著提升网站加载速度?  建站之星安装失败:服务器环境不兼容?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  如何在七牛云存储上搭建网站并设置自定义域名?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  如何快速启动建站代理加盟业务?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  黑客如何利用漏洞与弱口令入侵网站服务器?  外汇网站制作流程,如何在工商银行网站上做外汇买卖?  大连网站设计制作招聘信息,大连投诉网站有哪些?  建站之星代理如何优化在线客服效率?  高防服务器租用如何选择配置与防御等级?  如何批量查询域名的建站时间记录?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。