加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

如何利用 Vue 的 nextTick 技术解决问题

发布时间:2023-10-12 12:51:29 所属栏目:语言 来源:
导读:今天小编跟大家讲解下有关“Vue中的nextTick能解决什么问题,怎样使用”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。当数据发生变化之后,DOM视图

今天小编跟大家讲解下有关“Vue中的nextTick能解决什么问题,怎样使用”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。

当数据发生变化之后,DOM视图并不会立即更新,如果我们在发生变化之后立马去获取某个节点或者某个节点的值,很有可能结果就是undefined;因为Vue实现响应式并不是数据发生变化之后DOM立即变化,而是按一定的策略进行DOM的更新;

来看一个小demo:

App.vue

<template>

<div id="app">

<div ref="message">{{msg}}</div>

<div v-if="msg1">{{msg1}}</div>

<button @click="changeMsg">Change the Message</button>

</div>

</template>

<script>

export default {

name: "App",

data(){

return {

msg:"Hello Vue",

msg1: "",

}

},

methods:{

changeMsg(){

this.msg="hello world";

this.msg1=this.$refs.message.innerHTML;

console.log("更新DOM之前:"+this.msg1)

}

}

}

</script>

<style>

#app {

font-family: "Avenir", Helvetica, Arial, sans-serif;

-webkit-font-smoothing: antialiased;

-moz-osx-font-smoothing: grayscale;

text-align: center;

color: #2c3e50;

margin-top: 60px;

}

</style>

我们通过运行代码能够看到当我们不在this.$nextTick方法里面进行DOM操作的时候,this.$refs.message.innerHTML的值存储的还是之前的初始值;

修改代码:

App.vue

<template>

<div id="app">

<div ref="message">{{msg}}</div>

<div v-if="msg1">{{msg1}}</div>

<button @click="changeMsg">Change the Message</button>

</div>

</template>

<script>

export default {

name: "App",

data(){

return {

msg:"Hello Vue",

msg1: "",

}

},

methods:{

changeMsg(){

this.msg="hello world";

// this.msg1=this.$refs.message.innerHTML;

// console.log("更新DOM之前:"+this.msg1)

this.$nextTick(()=>{

this.msg1=this.$refs.message.innerHTML;

console.log("更新DOM之后:"+this.msg1)

})

}

}

}

</script>

<style>

#app {

font-family: "Avenir", Helvetica, Arial, sans-serif;

-webkit-font-smoothing: antialiased;

-moz-osx-font-smoothing: grayscale;

text-align: center;

color: #2c3e50;

margin-top: 60px;

}

</style>

修改代码之后我们可以发现,使用this.$nextTick很容易的就接收到了更新后的值,正如官网解释:在下次DOM更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的DOM;

再来修改代码对比一下:

App.vue

<template>

<div id="app">

<div ref="message">{{msg}}</div>

<div v-if="msg1">{{msg1}}</div>

<button @click="changeMsg">Change the Message</button>

</div>

</template>

<script>

export default {

name: "App",

data(){

return {

msg:"Hello Vue",

msg1: "",

}

},

methods:{

changeMsg(){

this.msg="hello world";

this.msg1=this.$refs.message.innerHTML;

console.log("更新DOM之前:"+this.msg1)

this.$nextTick(()=>{

this.msg1=this.$refs.message.innerHTML;

console.log("更新DOM之后:"+this.msg1)

})

}

}

}

</script>

<style>

#app {

font-family: "Avenir", Helvetica, Arial, sans-serif;

-webkit-font-smoothing: antialiased;

-moz-osx-font-smoothing: grayscale;

text-align: center;

color: #2c3e50;

margin-top: 60px;

}

</style>

经过修改代码,我们现在可以很容易看出来this.$nextTick(callback)的作用,callback是回调函数也就是我们要进行操作DOM的事情;

应用场景:

在vue的生命周期钩子函数created()中进行DOM操作的时候一定要把DOM操作放入到this.$nextTick()中;

因为在created钩子函数触发的时候,DOM是没有进行渲染的;DOM没有进行渲染,然后进行DOM操作无疑是徒劳的;

所以我们在created中进行DOM操作的时候,一定要将DOM操作放入到this.$nextTick()中;

与之相反的是mounted,因为当触发mounted的时候,DOM的挂载和渲染都已经完成了,所以在mounted中进行DOM操作是不会有任何问题的;

因为DOM更新是异步的,像v-if指令判断增删DOM元素,我们在方法中给变量赋值的时候,如果不使用this.$nextTick(),我们很有可能拿到的还是初始值,如果想拿到更新后的值,需要使用this.$nextTick()方法。

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章