Vue.js实例方法之生命周期详解

本文主要给大家介绍的是关于Vue.js实例方法之生命周期的相关内容分享出来供大家参考学习,学习的朋友们下面来一起看看详细的介绍:

一、$mount()挂载方法

$mount是用来挂载扩张的。如果 Vue 实例在实例化时没有收到 el 选项,则它处于“未挂载”状态,没有关联的 DOM 元素。可以使用 vm.$mount() 手动地挂载一个未挂载的实例。

比如我们扩张了一个全局组件,通过$mount手动的挂载到DOM上,也就生成一个Vue实例。

rush:xhtml;">

扩张一个全局组件,并且挂载到DOM上。

rush:js;"> //扩张全局的组件 var navBar = Vue.extend({ template: `
{{ title }}
`,data(){ return { title: 'Vue 扩展的全局组件' } },mounted(){ console.log('挂载上了') } })

//使用全局扩张的组件,挂载到id为#app的DOM上(会替换#app)
var vm = new navBar().$mount('#app');

//或者
var vm = new navBar({el: "#app"})

如果没有提供 elementOrSelector 参数,模板将被渲染为文档之外的的元素,并且必须使用原生DOM API把它插入文档中。

rush:js;"> //在文档之外渲染,并且挂载 var navbar = new navBar().$mount() document.getElementById('app').appendChild(navbar.$el)

二、$destroy()销毁方法

作用:

完全销毁一个实例。

Vue 实例销毁后调用调用后,Vue 实例相关的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

rush:xhtml;">

在组件中挂载destroyed生命周期钩子

rush:js;"> var navBar = Vue.extend({ template: `
{{ title }}

{{ num }}

`,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()
}

三、$forceUpdate()更新方法

方法是迫使Vue实例重新渲染。注意:它仅仅影响实例本身和插入插槽内容的子组件,而不是所有子组件。

代码

rush:xhtml;">
rush:js;"> //同样的,为了看到是否重新更新了数据,即是否执行了reload方法,我们在实例中添加updated选项 updated(){ console.log('数据重新渲染了') }

//三、更新数据方法
function reload(){
vm.$forceUpdate()
}

点击更新按钮,控制台打印出updated钩子中的输出,说明Vue实例重新渲染了。

四、$nextTick()数据修改方法

参数: {Function} [callback]

方法是构造器data中的数据被修改后触发,相当于updated钩子函数,但还是有区别的:它是在updated钩子函数执行完之后执行其里边的回调函数。也就是将回调延迟到下次 DOM 更新循环之后执行。在修改数据之后立即使用它,然后等待 DOM 更新。

rush:js;"> methods: { add(){ //更改数据 this.num++ this.$nextTick(function(){ console.log('DOM现在更新了') }) } },updated(){ console.log('数据更新成:'+this.num) }

通过控制台的打印结果,可以看到,当数据改变时,updated钩子早于$nextTick中的回调。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对编程之家的支持

相关文章

可以通过min-width属性来设置el-table-column的最小宽度。以...
yarn dev,当文件变动后,会自动重启。 yanr start不会自动重...
ref 用于创建一个对值的响应式引用。这个值可以是原始值(如...
通过修改 getWK005 函数来实现这一点。这里的 query 参数就是...
<el-form-item label="入库类型" ...
API 变动 样式类名变化: 一些组件的样式类名有所变动,可能需...