<div id="#app"></div>
//扩张全局的组件
var navBar = Vue.extend({
template: `<div>{{ title }}</div>`,
data(){
return {
title: 'Vue 扩展的全局组件'
}
},
mounted(){
console.log('挂载上了')
}
})
//使用全局扩张的组件,挂载到id为#app的DOM上(会替换#app)
var vm = new navBar().$mount('#app');
//或者
var vm = new navBar({el: "#app"})
//在文档之外渲染,并且挂载
var navbar = new navBar().$mount()
document.getElementById('app').appendChild(navbar.$el)
<div id="app"> </div> <button onclick="destroy()">销毁</button>
var navBar = Vue.extend({
template: `<div>
<div>{{ title }}</div>
<h2>{{ num }}</h2>
<button @click = 'add'>add</button>
</div>`,
data(){
return {
title: 'Vue 全局扩展组件',
num: 10
}
}
destroyed(){
console.log('销毁了')
},
methods: {
add(){
this.num++
}
}
})
//使用全局扩张的组件,挂载到id为#app的元素上
var vm = new navBar().$mount('#app');
//销毁
function destroy(){
//点击按钮,销毁vm实例,控制台会输出‘销毁了',当再次点击的时候不会输出,而且点击add按钮,数量也不会改变,说明已经销毁了
vm.$destroy()
}
<button onclick="reload()">刷新</button>
//同样的,为了看到是否重新更新了数据,即是否执行了reload方法,我们在实例中添加updated选项
updated(){
console.log('数据重新渲染了')
}
//三、更新数据方法
function reload(){
vm.$forceUpdate()
}
methods: {
add(){
//更改数据
this.num++
this.$nextTick(function(){
console.log('DOM现在更新了')
})
}
},
updated(){
console.log('数据更新成:'+this.num)
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有