zoukankan      html  css  js  c++  java
  • vue中nextTick的使用

          最近使用vue的vm.$nextTick的用法比较多,现在整理一下它的用法。

         推荐阅读:http://www.ruanyifeng.com/blog/2014/10/event-loop.html

       官方文档上这么说的:将回调延迟到下次DOM渲染之后执行。在修改数据后立即使用它,然后等待DOM更新。它和全局方法Vue.nextTick一样,不同的是回调的this自动绑定在它应用的实例上

      上述的话也可以这么理解,我们可以把需要在渲染DOM元素出来后的一些方法放在created生命周期中,不过需要借助vm.$nextTick() 这个回调函数中执行

      或者第二个用法就是在我们更新数据后,vm.$nextTick这个函数中,等待DOM更新时使用。

      其实项目中最常用的就是在组件中使用vm.$nextTick的方法,并且回调函数中的this,会自动绑定在当前的vue实例上

      举例: 

    //官网案例
    Vue.component('example', { template: '<span>{{ message }}</span>', data: function () { return { message: '未更新' } }, methods: { updateMessage() { this.message = '已更新' console.log(this.$el.textContent) // => '未更新' this.$nextTick(() => { console.log(this.$el.textContent) // => '已更新' }) } } })

    上述官方给的案例,我们也可以写成如下方式:通过使用ES7中的async/await的语法完成,这样后面输出的就是已更新的值

    methods: {
      updateMessage: async function () {
        this.message = '已更新'
        console.log(this.$el.textContent) // => '未更新'
        await this.$nextTick()
        console.log(this.$el.textContent) // => '已更新'
      }
    }

    我以项目中我的编写习惯举例

    <script>
        export default{
            name:'demo',
            data(){
               return {
        
               }
            },
            created(){
                 this.getAjaxData()
                 this.$nextTick(()=>{
                      this.getDomEl()
                 })
            },
           methods:{
               getAjaxData(){
                     //获取后台数据
               },
               getDomEl(){
                //需要获取DOM元素执行的函数;
                //或者放在mounted中执行的函数
               }
           }
        }
    
    </script>        
                          

    官网文档:注意 mounted 不会承诺所有的子组件也都一起被挂载。如果你希望等到整个视图都渲染完毕,可以用 vm.$nextTick 替换掉 mounted

    可以深入了解一下这个响应式原理的相关内容

      

  • 相关阅读:
    java基础问题1
    基本数据类型,string类型的瞎扯,final喜欢干的事儿。final string
    关于区块链不懂的东西
    需求更新表属性
    用户体验——响应时间
    后台运行任务nohup xxxxxx &
    jenkins打包maven工程发现有些包下载不下来
    jenkins复选框插件Extended Choice Parameter plugin
    jmeter上传文件tips
    airflow 简介
  • 原文地址:https://www.cnblogs.com/bllx/p/11888598.html
Copyright © 2011-2022 走看看