Vue里面的provided,inject实现响应式数据探索

Vue里面的provided,inject实现响应式数据探索这种传递数据的方式不是响应式的,官方文档说是可以为之,那么我们要实现响应式的传递,那该怎么处理呢?首先来看我们正常的使用方式:importSonfrom’./Son’exportdefault{provide(){return{text:this.test}},data(){return{test:”parent-text”}.

大家好,欢迎来到IT知识分享网。Vue里面的provided,inject实现响应式数据探索"

 这种传递数据的方式不是响应式的,官方文档说是刻意为之,那么我们要实现响应式的传递,那该怎么处理呢?

首先来看我们正常的使用方式:



  import Son from './Son'
  export default {
    provide () {
      return {
        text: this.test
      }
    },
    data () {
      return {
        test: "parent-text"
      }
    },
    created () {
      setTimeout(() => {
        this.test = 'new-parent-text' //这里test变化了,但是子组件接收到的未变
        this._provided.text = 'new-provided-text' //provide里面的变化了,但是子组件接收到还是未变化
        window.console.log(this._provided)
      }, 1000)
    },
    components: {
      Son
    }
  }

子组件

export default {
    inject: ['text'],
    data () {
      return {
        childText: this.text  //此时的数据并未更新
      }
    },
    computed: {

    },
  }

尝试一:

export default {
    inject: ['text'],
    data () {
      return {
        childTextOld: this.text
      }
    },
    created () {
      setTimeout(() => {
        // 子组件获得的foo 依旧是old words
        window.console.log(this.text)
      }, 2000)
    },
    computed: {
      childText () {
        return this.text //通过computed,我们知道data中有get/set,数据也是响应式的,但是现在还是没有更新
      }
    },

尝试二:

我们把父组件里面provide里面传入一个返回要暴露出去的函数,这个函数返回父组件的动态数据,然后在子孙组件里面调用这个函数。实际上这个函数存储了父组件实例的引用,所以每次子组件都能获取到最新的数据。

/*  provide () {
       return {
         text: this.test
       }
     }, */
    provide: function () {
      return {
        text: this.test,
        getReaciveNameFromParent: () => this.test
      }
    },
    data () {
      return {
        test: "parent-text"
      }
    },
    created () {
      setTimeout(() => {
        this.test = 'new-parent-text' //这里test变化了,但是子组件接收到的未变
        this._provided.text = 'new-provided-text' //
        window.console.log(this._provided)
      }, 1000)
    },
    components: {
      Son
    }

子组件的改造

inject: ['text', 'getReaciveNameFromParent'],
    data () {
      return {
        childTextOld: this.text,
      }
    },
    created () {
      setTimeout(() => {
        // 子组件获得的foo 依旧是old words
        window.console.log(this.text)
      }, 2000)
    },
    computed: {
      childText () {
        return this.text //通过computed,我们知道data中有get/set,数据也是响应式的,但是现在还是没有更新
      },
      reactiveNameFromParent () {
        return this.getReaciveNameFromParent()
      }
    },
    watch: {
      'reactiveNameFromParent': function (val) {
        window.console.log('来自Parent组件的name值发生了变化', val)
      }
    },
    mounted () {
      window.console.log(this.text, 'nameFromParent')
    }

这样就实现了想要的效果!

尝试三:

也是在第二种尝试的基础上进去的,就是利用传入的是引用地址,对象,实现数据的响应式接收

provide () {
      return {
        text: this.test
      }
    },

    data () {
      return {
        test: {
          a: "parent-text"
        }
      }
    },
    created () {
      setTimeout(() => {
        this.test.a = 'new-parent-text' //这里test变化了,但是子组件接收到的未变
        this._provided.text = 'new-provided-text' //
        window.console.log(this._provided)
      }, 1000)
    },
    components: {
      Son
    }

然后子组件正常接收即可

inject: ['text'],
    data () {
      return {
        childTextOld: this.text.a,
      }
    },
    created () {
      setTimeout(() => {
        // 子组件获得的foo 依旧是old words
        window.console.log(this.text)
      }, 2000)
    },
    computed: {
      childText () {
        return this.text.a //通过computed,我们知道data中有get/set,数据也是响应式的,但是现在还是没有更新
      },

    },

 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/15802.html

(0)
上一篇 2024-02-10 13:45
下一篇 2024-02-14 14:33

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信