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 相关文章推荐
JavaScript 函数式编程的原理
Oct 16 Javascript
模拟select的代码
Oct 19 Javascript
页面回到顶部的三种实现(锚标记,js)
Oct 01 Javascript
jquery $.fn $.fx是什么意思有什么用
Nov 04 Javascript
js中Image对象以及对其预加载处理示例
Nov 20 Javascript
JavaScript sort数组排序方法和自我实现排序方法小结
Jun 06 Javascript
Bootstrap模态框使用详解
Feb 15 Javascript
swiper动态改变滑动内容的实现方法
Jan 17 Javascript
利用js实现前后台传送Json的示例代码
Mar 29 Javascript
Vue.JS实现垂直方向展开、收缩不定高度模块的JS组件
Jun 19 Javascript
Vue中keep-alive组件作用详解
Feb 04 Javascript
JavaScript如何使用插值实现图像渐变
Jun 28 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
小偷PHP+Html+缓存
2006/12/20 PHP
AMFPHP php远程调用(RPC, Remote Procedure Call)工具 快速入门教程
2010/05/10 PHP
如何使用PHP实现javascript的escape和unescape函数
2013/06/29 PHP
ThinkPHP中的常用查询语言汇总
2014/08/22 PHP
Yii把CGridView文本框换成下拉框的方法
2014/12/03 PHP
PHP排序算法之冒泡排序(Bubble Sort)实现方法详解
2018/04/20 PHP
javascript图片预加载实例分析
2015/07/16 Javascript
js验证真实姓名与身份证号是否匹配
2015/10/13 Javascript
js纯数字逐一停止显示效果的实现代码
2016/03/16 Javascript
检查表单元素的值是否为空的实例代码
2016/06/16 Javascript
第一次接触神奇的Bootstrap菜单和导航
2016/08/01 Javascript
JavaScript随机打乱数组顺序之随机洗牌算法
2016/08/02 Javascript
AngularJS入门教程之更多模板详解
2016/08/19 Javascript
Node解决简单重复问题系列之Excel内容的获取
2018/01/02 Javascript
Vue路由钩子之afterEach beforeEach的区别详解
2018/07/15 Javascript
微信小程序自定义弹窗wcPop插件
2018/11/19 Javascript
Python中用于检查英文字母大写的isupper()方法
2015/05/19 Python
Python中工作日类库Busines Holiday的介绍与使用
2017/07/06 Python
python使用itchat实现手机控制电脑
2018/02/22 Python
python对日志进行处理的实例代码
2018/10/06 Python
Django Rest framework之权限的实现示例
2018/12/17 Python
浅谈多卡服务器下隐藏部分 GPU 和 TensorFlow 的显存使用设置
2020/06/30 Python
python3让print输出不换行的方法
2020/08/24 Python
详解Django中views数据查询使用locals()函数进行优化
2020/08/24 Python
马来西亚航空官方网站:Malaysia Airlines
2017/07/28 全球购物
澳大利亚冲浪和时尚服装网上购物:SurfStitch
2017/07/29 全球购物
凯伦·米莲女装网上商店:Karen Millen
2017/11/07 全球购物
院药学专业个人求职信
2013/09/21 职场文书
工地质量标语
2014/06/12 职场文书
个人汇报材料范文
2014/12/30 职场文书
2015年前台接待工作总结
2015/05/04 职场文书
歼十出击观后感
2015/06/11 职场文书
七个Python必备的GUI库
2021/04/27 Python
Java方法重载和方法重写的区别到底在哪?
2021/06/11 Java/Android
Nginx 路由转发和反向代理location配置实现
2021/11/11 Servers
Python安装使用Scrapy框架
2022/04/12 Python