vue2 provide/inject watch 监控inject中值变化

在Vue 2.x中,使用inject注入的值默认情况下是不能被watch直接监控到的,因为inject提供的值不是响应式的。这是Vue 2.x的设计,与Vue 3.x中的provideinject不同,Vue 3.x中的inject提供的值是响应式的,可以直接被watch监控到。

如果你希望在Vue 2.x中监控inject中的值的变化

使用计算属性或引用类型的响应式数据 :将inject提供的值保存在组件的响应式数据中,然后使用计算属性或watch来监控这个响应式数据的变化。例如:

复制代码
<template>
  <div>
    <p>{{ injectedValue }}</p>
  </div>
</template>

<script>
export default {
  inject: ['injectedValue'],
  data() {
    return {
      // 将 injectedValue 存储在响应式数据中
      valueToWatch: this.injectedValue,
    };
  },
  watch: {
    valueToWatch(newValue, oldValue) {
      console.log('injectedValue 变化:', newValue, oldValue);
      // 在这里可以执行相应的操作
    },
  },
};
</script>

示例二、

父组件:

复制代码
<template>
  <div @click="changeMap"></div>
</template>

<script>
export default {
   provide() {
        return {
            mapLoad: this.mapLoad,
        };
    },
  data(){
        return {
            isLoadMap: false
        }
    },
  methods: {
        mapLoad(){
            return this.isLoadMap
        },
        changeMap(){
           this.isLoadMap = !this.isLoadMap
        }
    },
};
</script>

inject使用的地方

复制代码
<template>
  <div>
  </div>
</template>

<script>
export default {
  inject: ['mapLoad'],
   computed: {
        watchloadmap() {
            return this.mapLoad()
        }
    },
  watch: {
    watchloadmap(newValue, oldValue) {
      console.log('injectedValue 变化:', newValue, oldValue);
      // 在这里可以执行相应的操作
    },
  },
};
</script>

注意事项:

相关推荐
昔人'6 分钟前
css`text-wrap:pretty`
前端·css
勇敢di牛牛12 分钟前
Vue+mockjs+Axios 案例实践
前端·javascript·vue.js
Sheldon一蓑烟雨任平生22 分钟前
Vue3 Class 与 Style 绑定
vue.js·vue3·class与style绑定·绑定class·绑定style·vue3绑定class·vue3绑定style
詩句☾⋆᭄南笙22 分钟前
HTML列表、表格和表单
服务器·前端·html·表格·列表·表单
IT_陈寒34 分钟前
Python性能翻倍的5个冷门技巧:从GIL逃逸到内存视图的实战优化指南
前端·人工智能·后端
南城巷陌39 分钟前
错误边界:用componentDidCatch筑起React崩溃防火墙
前端·react.js·前端框架
FinClip44 分钟前
OpenAI推出Apps SDK,你的企业App跟上了吗?
前端·app·openai
馨谙1 小时前
Linux中的管道与重定向:深入理解两者的本质区别
前端·chrome
Rhys..1 小时前
JS - npm init
开发语言·javascript·npm
夏天想1 小时前
复制了一个vue的项目然后再这个基础上修改。可是通过npm run dev运行之前的老项目,发现运行的竟然是拷贝后的项目。为什么会这样?
前端·vue.js·npm