Vue props传入function时的this指向问题_vue props function-CSDN博客

Vue props传入function时的this指向问题

Parent.vue

bash 复制代码
<template>
  <div>
    <Child :func="parentFunc"></Child>
  </div>
</template>

<script>
import Child from './Child'
export default {
  data () {
    return {
      msg: 'this is parent.'
    }
  },
  components: {
    Child
  },
  methods: {
    parentFunc () {
      console.log(this.msg)
    }
  }
}
</script>

Child.vue

bash 复制代码
<template>
  <div>
    <button @click="childFunc">click</button>
  </div>
</template>

<script>
export default {
  props: {
    func: {
      require: false,
      type: Function,
      default: () => {
        return () => {
          console.log(this.msg)
        }
      }
    }
  },
  data () {
    return {
      msg: 'this is child.'
    }
  },
  methods: {
    childFunc () {
      this.func()
    }
  }
}
</script>

踩坑 笔记

  • props传入function时,函数中this自动绑定Vue实例;
  • 在H5的Vue中项目中,console将输出 "this is parent.";
    但在uni-app小程序中使用Vue时,console将输出"this is child";
  • 我的解决方案:
    将父组件msg作为参数传给子组件,子组件props接收msg,然后在父组件的parantFunc中,无论this 指向父组件还是子组件,this.msg总能取得正确的值;
  • 为什么不使用v-on监听子组件事件并用$emit触发事件?
    1. Vue中不推荐向子组件传递Function的方式,因为Vue有更好的事件父子组件通信机制;
    2. 我的原因:项目中的子组件是一个公共组件,原本的代码是使用props+Function的方式,且存在默认值,默认调用函数default默认值;如果改为事件$emit的方式,则涉及修改的地方较多;
    3. 因此,在尽量不影响原来的业务代码的原则下,采用上述解决方案解决该问题;
相关推荐
写代码的皮筏艇2 小时前
replace方法
前端·javascript
C澒2 小时前
AI 生码 - API2CODE:接口智能匹配与 API 自动化生码实践
前端·低代码·ai编程
idcu2 小时前
Lyt.js AI:让前端开发进入智能生成时代
前端
idcu2 小时前
深入 Lyt.js 编译器:.lyt 文件如何增强 HTML 模板能力
前端
即答侠2 小时前
实时 AI copilot 的 4 级 fallback 设计:用户感知 0 中断,SLA 从 92% 拉到 99.6%
前端·人工智能
无心使然2 小时前
Openlayers调用ArcGis地图服务之五 —— 要素识别(/identify)
前端·vue.js·数据可视化
Dxy12393102162 小时前
HTML 如何设置 Div 阴影悬浮边框:从基础到进阶
前端·html·css3
好运的阿财2 小时前
OpenClaw工具拆解之browser+agents_list
前端·人工智能·机器学习·开源软件·ai编程·openclaw·openclaw工具
JarvanMo2 小时前
八个开源Flutter应用,让你成为更好的开发者
前端