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


Posted in Javascript onJuly 03, 2017

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

一、$mount()挂载方法

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

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

<div id="#app"></div>

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

//扩张全局的组件
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"})

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

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

二、$destroy()销毁方法

作用: 完全销毁一个实例。

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

<div id="app">

</div>
<button onclick="destroy()">销毁</button>

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

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

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

三、$forceUpdate()更新方法

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

看代码:

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

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

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

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

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

参数: {Function} [callback]

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

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

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

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

总结

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

Javascript 相关文章推荐
jQuery textarea的长度进行验证
May 06 Javascript
Javascript 实现的数独解题算法网页实例
Oct 15 Javascript
在myeclipse中如何加入jquery代码提示功能
Jun 03 Javascript
D3.js 从P元素的创建开始(显示可加载数据)
Oct 30 Javascript
json+jQuery实现的无限级树形菜单效果代码
Aug 27 Javascript
JQuery EasyUI的一些常用组件
Jul 12 jQuery
BootStrap Fileinput插件和Bootstrap table表格插件相结合实现文件上传、预览、提交的导入Excel数据操作步骤
Aug 07 Javascript
详解VUE-地区选择器(V-Distpicker)组件使用心得
May 07 Javascript
使用webpack编译es6代码的方法步骤
Apr 28 Javascript
JSX在render函数中的应用详解
Sep 04 Javascript
javascript设计模式 ? 备忘录模式原理与用法实例分析
Apr 21 Javascript
vue实现列表拖拽排序的功能
Nov 02 Javascript
基于Vuejs和Element的注册插件的编写方法
Jul 03 #Javascript
Async Validator 异步验证使用说明
Jul 03 #Javascript
在vue-cli脚手架中配置一个vue-router前端路由
Jul 03 #Javascript
Require.js的基本用法详解
Jul 03 #Javascript
React利用插件和不用插件实现双向绑定的方法详解
Jul 03 #Javascript
解决webpack -p压缩打包react报语法错误的方法
Jul 03 #Javascript
JS 学习总结之正则表达式的懒惰性和贪婪性
Jul 03 #Javascript
You might like
截获网站title标签之家内容的例子
2006/10/09 PHP
php采用curl模仿登录人人网发布动态的方法
2014/11/07 PHP
php过滤所有的空白字符(空格、全角空格、换行等)
2015/10/27 PHP
变量在 PHP7 内部的实现(二)
2015/12/21 PHP
PHP怎样用正则抓取页面中的网址
2016/08/09 PHP
Laravel 模型使用软删除-左连接查询-表起别名示例
2019/10/24 PHP
prototype Element学习笔记(篇二)
2008/10/26 Javascript
前淘宝前端开发工程师阿当的PPT中有JS技术理念问题
2010/01/15 Javascript
JavaScript this调用规则说明
2010/03/08 Javascript
Web跨浏览器进程通信(Web跨域)
2013/04/17 Javascript
利用CSS、JavaScript及Ajax实现高效的图片预加载
2013/10/16 Javascript
jquery easyui combobox模糊过滤(示例代码)
2013/11/30 Javascript
jQuery中复合属性选择器用法实例
2014/12/31 Javascript
JavaScript Split()方法
2015/12/18 Javascript
javascript 初学教程及五子棋小程序的简单实现
2017/07/04 Javascript
鼠标拖动改变DIV等网页元素的大小的实现方法
2017/07/06 Javascript
基于jQuery Easyui实现登陆框界面
2017/07/10 jQuery
js 概率计算(简单版)
2017/09/12 Javascript
原生js调用json方法总结
2018/02/22 Javascript
vue.js使用watch监听路由变化的方法
2018/07/08 Javascript
webpack 从指定入口文件中提取公共文件的方法
2018/11/13 Javascript
vue配置接口域名方法总结
2019/05/12 Javascript
[01:32:22]DOTA2-DPC中国联赛 正赛 Ehome vs VG BO3 第一场 2月5日
2021/03/11 DOTA
tensorflow入门之训练简单的神经网络方法
2018/02/26 Python
Python自定义函数计算给定日期是该年第几天的方法示例
2019/05/30 Python
jupyter notebook 实现matplotlib图动态刷新
2020/04/22 Python
警校毕业生自我评价
2014/04/06 职场文书
建筑工程技术专业求职信
2014/07/16 职场文书
医生党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
小学教师自我剖析材料
2014/09/29 职场文书
2014年保卫部工作总结
2014/11/21 职场文书
法人代表证明书范本
2015/06/18 职场文书
学校安全管理制度
2015/08/06 职场文书
2016春季田径运动会广播稿
2015/12/21 职场文书
Python实现排序方法常见的四种
2021/07/15 Python
10大幻兽系恶魔果实 蝙蝠果实上榜,第一自愈能力强
2022/03/18 日漫