Vue高级特性之nextTick具体案例讲解

先通过一个案例具体讲解

<template>
  <div>
    <div id="app">
      <ul ref="ul1">
        <li v-for="(item,index) in list" :key="index">
        {{item}}
        </li>
      </ul>
      <button @click="addItem">添加一项</button>
    </div>
  </div>
</template>

<script>
export default {
   data() {
     return {
       list:['a','b','c']
     }
   },
   methods: {
     addItem(){
       this.list.push(`${Date.now()}`)
       this.list.push(`${Date.now()}`)
       this.list.push(`${Date.now()}`)
     
       //获取DOM元素
       const ulElem = this.$refs.ul1
       //eslint-disable-next-line
       console.log(ulElem.childNodes.length)
       
     }
   },
}
</script>

打印出来是什么样的呢?
在这里插入图片描述

不觉得很奇怪吗,我们ul里面明明有9个li标签,但是显示它的子节点长度只有6个

因为当data里面的数据改变的时候,dom不会立刻去改变,此时获取不到最新的,vue是异步渲染的,所以当第一次添加的时候,显示的子节点长度其实是之前的a,b,c的长度,

那我们想当点击完之后立即拿到结果怎么办?很简单,我们把它用nexttick包裹起来

  this.$nextTick(()=>{
       //获取DOM元素
       const ulElem = this.$refs.ul1
       //eslint-disable-next-line
       console.log(ulElem.childNodes.length)
       })

总结一下:

vue是异步渲染
data改变之后,DOM不会立刻渲染
$nexttick会在DOM渲染之后被触发,以获取最新DOM节点
页面渲染时会将data的修改做整合,多次data修改只会渲染一次

下面再介绍一下异步组件,何为异步组件,就是按需加载,异步加载大组件

还是用一个例子说明一下

<template>
  <div>
<bigDeom v-if="isShow"></bigDeom>
<button @click="isShow = true"></button>
  </div>
</template>

<script>
export default {
// import()函数
components:{
  // bigDeom:()=>import('')  会向这样引入,而不是在外面直接import引入
  // 这样写当我们第一次进入页面的时候,这个组件不会被加载,当我们点击按钮时候它才会加载出来,
  // 这样可以极大优化性能
},
data() {
  return {
    isShow:false
  }
},
}
</script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值