Vue 混合

混合(mixins)是一种分发vue组件中可复用功能的非常灵活的方式。混合对象可以可以包含任意组件选项。以组件使用混合对象时,所有混合对象的选项将被混合到该组件本身的选项。

//定义一个混合对象

var myMixins = {

created:function(){

this.hello();

},

methods:{

hello:function(){

console.log(‘hello from mixin!‘);

}

}

}

//定义一个使用混合对象的组件

var Component = vue.extend({

mixins:[myMIxins]

});

var component = new Component();// -->hello from mixin!

选项合并

当组件和混合对象含有同名选项时,这些选项将以恰当的方式混合。比如,同名钩子函数将混合为一个数组,因此都将被调用。

混合对象的钩子将在组件自身钩子之前调用。


var mixin = {

created: function () {

console.log(‘混合对象的钩子被调用‘)

}

}

new Vue({

mixins: [mixin],

created: function () {

console.log(‘组件钩子被调用‘)

}

})

值为对象的选项,例如methods,component ,和directives,将被混合为同一个对象,两个对象键名冲突时,取组件对象的键值对。

var mixin = {

methods:function(){

console.log(‘foo‘)

}

conflicting:function(){

console.log(‘mixin‘)

}

}

var vm = new Vue({

mixins:[mixin],

methods:{

bar:function(){

console.log(‘bar‘)

},

conflicting:function(){

console.log(‘from self‘)

}

}

})

vm.foo();

vm.bar();

vm.conflicting();

时间: 2024-12-13 15:10:39

Vue 混合的相关文章

11、VUE混合

1.混合的概念(mixture) 混合是以一种灵活的方式,为组件提供代码复用功能.(类似于封装) 混合对象可以包含任意的组件选项.当组件使用了混合对象时,混合对象的所有选项将被“混入”组件自己的选项中. 2.混合的例子 使用混合实现Modal窗口. html{    width:100%;    height:100%;}body{    width:inherit;    height:inherit; /*继承父控件的高度 */    margin: 0;    padding: 0;}.m

实现一个简单的vue-router

所有项目的源代码都放在我的github上,欢迎大家start: https://github.com/Jasonwang911/my-vue-router 首先来看下vue-router的使用: import Vue from 'vue';import VueTouter from 'vue-router'; // VueRouter 是一个类,用来new 一个实例 // 注册vue-routerVue.use(VueRouter); new VueRouter({ mode: 'hash',

Vue.js 基础学习之混合mixins

混合以一种灵活的方式为组件提供分布复用功能.混合对象可以包含任意的组件选项.当组件使用了混合对象时,混合对象的所有选项将被"混入"组件自己的选项中. 当混合对象与组件包含同名选项时,这些选项将以适当的策略合并.例如,同名钩子函数被并入一个数组,因而都会被调用.另外,混合的钩子将在组件自己的钩子之前调用. 我自己的理解是:混合就是将一些相似组件的相同部分用一个对象封装起来,实现代码的复用.当然如果在组件中重新定义某些东西就会覆盖掉来自混合的相应部分. 混合的使用:首先将公共部分写入一个对

vue里面的Mixins(混合)

Mixins一般有两种用途:1.在你已经写好了构造器后,需要增加方法或者临时的活动时使用的方法,这时用混入会减少源代码的污染.2.很多地方都会用到的公用方法,用混入的方法可以减少代码量,实现代码重用.一.Mixins的基本用法我们现在有个数字点击递增的程序,假设已经完成了,这时我们希望每次数据变化时都能够在控制台打印出提示:"数据发生变化".代码实现过程: <!DOCTYPE html> <html lang="en"> <head&g

vue 与原生app的对接交互(混合开发)

小伙伴们在用vue开发h5项目特别是移动端的项目,很多都是打包后挂载在原生APP上的,那就少不了与原生交互了,我最近就是在坐这个,踩了一些坑,拿出来给大家分享下. 0.通过url传输数据:(一般是在入口页面传下app的用户信息进来供vue h5使用) 1 methods: { 2 // 接收url后的数据 3 urltext() { 4 let loc = location.href; 6 let n1 = loc.length;//地址的总长度 7 let n2 = loc.indexOf("

Vue+原生App混合开发手记#2 融云即时通讯

最近开发的一个医药项目中要求加入即时通讯,最后选择了融云IM即时通讯服务,融云即时通讯包含Android SDK,iOS SDK以及Web SDK,为了节省开发时间,使用了Web SDK,这样在Android平台和iOS平台上都能表现一致.这是部分界面的效果, 分为两类用户,一类是医生,接受患者的咨询,一类是患者,可以与医生交流: 医生用户看到的界面 患者用户看到的界面 聊天界面       获取App Key 首先进入融云官网,找到Web SDK开发指南,按照提示先注册一个账号,拿到AppKe

Vue内容分发slot

前面的话 为了让组件可以组合,需要一种方式来混合父组件的内容与子组件自己的模板.这个过程被称为 内容分发 (或 “transclusion” ).Vue实现了一个内容分发 API,参照了当前 Web 组件规范草案,使用特殊的 <slot> 元素作为原始内容的插槽.本文将详细介绍Vue内容分发slot 编译作用域 在深入内容分发 API 之前,先明确内容在哪个作用域里编译.假定模板为 <child-component> {{ message }} </child-compone

vue+cordova项目

教你用Cordova打包Vue项目 现在国内越来越多的开发者使用Vue开发混合app,但是当大家开发完成过后才发现不知道该怎么将Vue项目打包成app.据我现在的了解打包Vue项目目前流行的就是使用weex和cordova.weex是阿里提供并且Vue的作者也极力推荐的,有兴趣的可以去学习使用一下.因为我本身是做angular+ionic的,所以比较青睐cordova,下面我就教大家怎么使用cordova打包Vue项目: 第一步:安装cordova 如果已经安装则直接跳过,否则执行以下命令: n

Vue学习笔记入门篇——组件的内容分发(slot)

本文为转载,原文:Vue学习笔记入门篇--组件的内容分发(slot) 介绍 为了让组件可以组合,我们需要一种方式来混合父组件的内容与子组件自己的模板.这个过程被称为 内容分发 (或 "transclusion" 如果你熟悉 Angular).Vue.js 实现了一个内容分发 API,使用特殊的 'slot' 元素作为原始内容的插槽. 编译作用域 在深入内容分发 API 之前,我们先明确内容在哪个作用域里编译.假定模板为: <child-component> {{ messa