生命周期钩子函数

举报
yd_249383650 发表于 2023/03/18 22:43:00 2023/03/18
【摘要】 ​ 1、生命周期每个 Vue 实例在被创建时都要经过一系列的初始化过程 :创建实例,装载模板,渲染模 板等等。Vue 为生命周期中的每个状态都设置了钩子函数(监听函数)。每当 Vue 实例处于 不同的生命周期时,对应的函数就会被触发调用。 生命周期:你不需要立马弄明白所有的东西。​编辑2、钩子函数 beforeCreated:我们在用 Vue 时都要进行实例化,因此,该函数就是在 Vue ...

 1、生命周期

每个 Vue 实例在被创建时都要经过一系列的初始化过程 :创建实例,装载模板,渲染模 板等等。Vue 为生命周期中的每个状态都设置了钩子函数(监听函数)。每当 Vue 实例处于 不同的生命周期时,对应的函数就会被触发调用。 生命周期:你不需要立马弄明白所有的东西。

编辑


2、钩子函数

 beforeCreated:我们在用 Vue 时都要进行实例化,因此,该函数就是在 Vue 实例化时调 用,也可以将他理解为初始化函数比较方便一点,在 Vue1.0 时,这个函数的名字就是

init。

 created:在创建实例之后进行调用。

 beforeMount:页面加载完成,没有渲染。如:此时页面还是{{name}}

 mounted:我们可以将他理解为原生 js 中的 window.onload=function({.,.}),或许大家也在 用 jquery,所以也可以理解为 jquery 中的$(document).ready(function(){….}),他的功能就 是:在 dom 文档渲染完毕之后将要执行的函数,该函数在 Vue1.0 版本中名字为

compiled。 此时页面中的{{name}}已被渲染成张三

 beforeDestroy:该函数将在销毁实例前进行调用 。

 destroyed:改函数将在销毁实例时进行调用。

 beforeUpdate:组件更新之前。

 updated:组件更新之后。

<body>
<div id="app">
<span id="num">{{num}}</span>
<button v-on:click="num++">赞!</button>
<h2>

{{name}},非常帅!!!有{{num}}个人点赞。

</h2>
</div>
</body>
<script src="../node_modules/vue/dist/vue.js"></script>
<script>

let app = new Vue({

el: "#app",

data: {

name: "张三",

num: 100

},

methods: {

show() {

return this.name;
},

add() {

this.num++;
}
},

beforeCreate() {
console.log("=========beforeCreate=============");

console.log("数据模型未加载:" + this.name, this.num);

console.log("方法未加载:" + this.show());

console.log("html 模板未加载:

" + document.getElementById("num"));
},

created: function () {

console.log("=========created=============");

console.log("数据模型已加载:" + this.name, this.num);

console.log("方法已加载:" + this.show());

console.log("html 模板已加载:

" + document.getElementById("num"));

console.log("html 模板未渲染:

" + document.getElementById("num").innerText);
},

beforeMount() {

console.log("=========beforeMount=============");

console.log("html 模板未渲染:

" + document.getElementById("num").innerText);
},

mounted() {

console.log("=========mounted=============");

console.log("html 模板已渲染:

" + document.getElementById("num").innerText);
},

beforeUpdate() {

console.log("=========beforeUpdate=============");

console.log("数据模型已更新:" + this.num);

console.log("html 模板未更新:

" + document.getElementById("num").innerText);
},

updated() {

console.log("=========updated=============");

console.log("数据模型已更新:" + this.num);

console.log("html 模板已更新:

" + document.getElementById("num").innerText);
}
});

</script>

 

 beforeCreated:我们在用 Vue 时都要进行实例化,因此,该函数就是在 Vue 实例化时调 用,也可以将他理解为初始化函数比较方便一点,在 Vue1.0 时,这个函数的名字就是

init。

 created:在创建实例之后进行调用。

 beforeMount:页面加载完成,没有渲染。如:此时页面还是{{name}}

 mounted:我们可以将他理解为原生 js 中的 window.onload=function({.,.}),或许大家也在 用 jquery,所以也可以理解为 jquery 中的$(document).ready(function(){….}),他的功能就 是:在 dom 文档渲染完毕之后将要执行的函数,该函数在 Vue1.0 版本中名字为

compiled。 此时页面中的{{name}}已被渲染成张三

 beforeDestroy:该函数将在销毁实例前进行调用 。

 destroyed:改函数将在销毁实例时进行调用。

 beforeUpdate:组件更新之前。

 updated:组件更新之后



【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。