1.Vue.extend
场景:vue 组件中有些需要将一些元素挂载到元素上,这个时候 extend 就起到作用了
是构造一个组件的语法器
写法:
var Profile = Vue.extend({
template: '<p>{{extendData}}</br>实例传入的数据为:{{propsExtend}}</p>',
data: function () {
return {
extendData: '这是extend扩展的数据',
}
},
props:['propsExtend']
})
new Profile({propsData:{propsExtend:'我是实例传入的数据'}}).$mount('#app-extend')
Vue.component('Profile',Profile)
2.mixins
场景:有些组件有些重复的 js 逻辑,如校验手机验证码,解析时间等,mixins 就可以实现这种混入
mixins 值是一个数组
const mixin={
created(){
this.dealTime()
},
methods:{
dealTime(){
console.log('这是mixin的dealTime里面的方法');
}
}
}
export default{
mixins:[mixin]
}
3.extends
extends用法和mixins很相似,只不过接收的参数是简单的选项对象或构造函数,所以extends只能单次扩展一个组件
const extend={
created(){
this.dealTime()
},
methods:{
dealTime(){
console.log('这是mixin的dealTime里面的方法');
}
}
}
export default{
extends:extend
}
4.Vue.use()
场景:我们使用 element时会先 import,再 Vue.use()一下,实际上就是注册组件,触发 install 方法;
这个在组件调用会经常使用到;
会自动组织多次注册相同的插件.
5.install
场景:在 Vue.use()说到,执行该方法会触发 install
是开发vue的插件,这个方法的第一个参数是 Vue 构造器,第二个参数是一个可选的选项对象(可选)
var MyPlugin = {};
MyPlugin.install = function (Vue, options) {
Vue.directive('click', {
bind(el, binding, vnode, oldVnode) {
console.log('指令my-directive的bind执行啦');
},
inserted: function(el){
console.log('指令my-directive的inserted执行啦');
},
update: function(){
console.log('指令my-directive的update执行啦');
},
componentUpdated: function(){
console.log('指令my-directive的componentUpdated执行啦');
},
unbind: function(){
console.log('指令my-directive的unbind执行啦');
}
})
Vue.mixin({
created: function () {
console.log('注入组件的created被调用啦');
console.log('options的值为',options)
}
})
Vue.prototype.$myMethod = function (methodOptions) {
console.log('实例方法myMethod被调用啦');
}
}
Vue.use(MyPlugin,{someOption: true })
new Vue({
el: '#app'
});
6.Vue.nextTick
场景:页面加载时需要让文本框获取焦点
用法:在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM
mounted(){
this.$nextTick(() => {
this.$refs.inputs.focus()
})
}