首页前端开发VUEVue props传入function时的this指向问题解读

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

时间2024-02-11 05:50:03发布访客分类VUE浏览635
导读:收集整理的这篇文章主要介绍了Vue props传入function时的this指向问题解读,觉得挺不错的,现在分享给大家,也给大家做个参考。 目录Vue props传入function时...
收集整理的这篇文章主要介绍了Vue props传入function时的this指向问题解读,觉得挺不错的,现在分享给大家,也给大家做个参考。
目录
  • Vue props传入function时的this指向
  • 踩坑笔记
    • 我的解决方案
  • Vue props 传递函数
    • Props的type是函数
  • 总结

    Vue PRops传入function时的this指向

    Parent.vue

    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

    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”;

    @H_777_56@我的解决方案

    将父组件msg作为参数传给子组件,子组件props接收msg,然后在父组件的parantFunc中,无论this 指向父组件还是子组件,this.msg总能取得正确的值;

    为什么不使用v-on监听子组件事件并用$emIT触发事件?

    • Vue中不推荐向子组件传递Function的方式,因为Vue有更好的事件父子组件通信机制;
    • 我的原因:项目中的子组件是一个公共组件,原本的代码是使用props+Function的方式,且存在默认值,默认调用函数default默认值;如果改为事件$emit的方式,则涉及修改的地方较多;
    • 因此,在尽量不影响原来的业务代码的原则下,采用上述解决方案解决该问题;

    Vue props 传递函数

    Props的type是函数

    通过 props 传递 函数 看看有啥用。

    // 父组件/template>
         div>
            children :add='childrenClick'>
        /children>
            p>
    {
    {
    countF}
    }
        /p>
          /div>
        /template>
        script>
    import children from './Children'export default {
      name: 'HelloWorld',  data() {
        return {
          countF: 0,    }
      }
    ,  methods: {
        childrenClick(c){
             this.countF += c;
        }
      }
    ,  components:{
        children,  }
    }
        /script>
        // 子组件template>
            div>
                button @click="handClick(count)">
        点击加 1 /button>
            /div>
        /template>
        script>
    export default {
        data() {
            return {
                count:1,        }
        }
    ,    props:{
            add:{
                type: Function        }
        }
    ,    methods: {
            handClick(){
                    this.add( ++this.count);
     // 父组件方法        }
        }
    ,}
        

    可以看到 chirden 组件在中 使用 props.add() , 调用的是 父组件的方法。

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

    您可能感兴趣的文章:
    • vue中使用props传值的方法
    • vue父组件通过props如何向子组件传递方法详解
    • 解决vue props传Array/Object类型值,子组件报错的情况

    声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


    若转载请注明出处: Vue props传入function时的this指向问题解读
    本文地址: https://pptw.com/jishu/609401.html
    Vue3+Tsx给路由加切换动画时的踩坑及解决 详解Vue如何监测数组的变化

    游客 回复需填写必要信息