Vue父子通信的问题

VUE组件父子间通信,父组件给子组件传值用props,子组件给父组件传值用this.$emit()方法,下面是详细的示例,希望能对大家有所帮助。
第一部分讲解的是父传子。

//父组件里边的内容
<template>
  <div id="father">
    <p>我是你爸爸我真伟大{{message}}</p>

    <son :sondata="mydata"></son>
  </div>
</template>
<script>
import Son from "./son";
export default {
  data() {
    return {
      message: "养你这么大",
      mydata: "长大要好好孝敬他"
    };
  },
  components: {
    Son
  }
};
</script>
<style lang="less">
</style>
//子组件里边的内容
<template>
  <div>
    <p>
      这是父亲告诉我的,
      <span class="mess">{{sondata}}</span>
    </p>
  </div>
</template>
<script>
export default {
  props: {
    sondata: {
      type: String,
      default: function() {
        return "";
      }
    }
  },
  data() {
    return {};
  }
};
</script>
<style lang="less">
.mess {
  color: red;
}
</style>

用V-bind(简写:)将父组件传的值绑定在子组件中,父组件需要传的具体内容,放在本组件里边的(也就是上边定义的mydata里边),在子组件里边需要接受内容,这里用到了props,设置接受组件内传数据的名字也就是sondata,它的类型是String,有默认的返回值,这些自己设置一下就可以,固定的语法
接下来是第二部分子传父

//子组件
<template>
  <div>
    <p>爸爸我要告诉你,</p>
    <button @click="toFatherData">给爸爸的话</button>
  </div>
</template>
<script>
export default {
  props: {
    sondata: {
      type: String,
      default: function() {
        return "";
      }
    }
  },
  data() {
    return {};
  },
  methods: {
    toFatherData() {
      this.$emit("sendparents", "我已经长大,可以替你分担压力");
    }
  }
};
</script>
<style lang="less">
</style>

//父组件
<template>
  <div id="father">
    <son @sendparents="sendSonData"></son>
    <p>{{sendsonmessage}}</p>
  </div>
</template>
<script>
import Son from "./son";
export default {
  data() {
    return {
      sendsonmessage: ""
    };
  },
  components: {
    Son
  },
  methods: {
    sendSonData(data) {
      this.sendsonmessage = data;
    }
  }
};
</script>
<style lang="less">
</style>

子组件里边创建按钮,定义一个点击事件,点击事件里边用this.$emit方法触发一个自定义事件,并传递一个参数
在父组件的子标签中,监听该自定义事件(sendparents)并添加一个响应该事件的处理方法(sendSonData),将接收到的值赋值给data中的sendsonmessage

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值