Vue页面传值:Props属性与$emit事件的应用介绍

一、vue页面传值

在Vue页面中传值有多种方式,简单介绍以下两种

  1. 通过props属性传递值:父组件在子组件上定义props属性,子组件通过props接收父组件传递的值。
  2. 通过emit触发事件传递值:子组件通过emit方法触发一个自定义事件,并传递需要传递的值给父组件。

二、案例实践

2.1 props属性传递值方式

父组件:

html 复制代码
<template>
  <div>
    <ChildComponent :message="message" />
  </div>
</template>

<script>
import ChildComponent from './ChildComponent.vue';

export default {
  components: {
    ChildComponent,
  },
  data() {
    return {
      message: 'Hello World!'
    };
  },
};
</script>

子组件(ChildComponent.vue):

html 复制代码
<template>
  <div>{{ message }}</div>
</template>

<script>
export default {
  props: {
    message: {
      type: String,
      required: true,
    },
  },
};
</script>
2.2 $emit触发事件传递值

父组件:

html 复制代码
<template>
  <div>
    <ChildComponent @message="handleMessage" />
  </div>
</template>

<script>
import ChildComponent from './ChildComponent.vue';

export default {
  components: {
    ChildComponent,
  },
  methods: {
    handleMessage(message) {
      console.log(message);
    },
  },
};
</script>

子组件(ChildComponent.vue):

html 复制代码
<template>
  <div>
    <button @click="sendMessage">Send Message</button>
  </div>
</template>

<script>
export default {
  methods: {
    sendMessage() {
      this.$emit('message', 'Hello World!');
    },
  },
};
</script>

这两种方式都可以实现在Vue页面间传值,具体使用哪种方式取决于你的需求和组件间的关系。

  • 通过props属性传递值方式适用于父组件向子组件传递数据的场景,可以直接传递数据,简洁方便,但数据传递是单向的。
  • 通过$emit触发事件传递值方式适用于子组件向父组件传递数据的场景,可以实现双向数据传递,但需要在父组件中监听子组件的自定义事件,可能会导致代码冗余。
相关推荐
walking957几秒前
React 入门到进阶全攻略
前端·react.js
walking957几秒前
React 从基础到架构实践
前端·react.js
盏灯几秒前
🔥PM:十万火急,客户数据被截图泄密了,紧急需求加水印...
前端
一个专注api接口开发的小白3 分钟前
从零搭建淘宝数据采集系统:商品 API 接口调用与 OAuth2.0 认证实践
前端·数据挖掘·api
万少28 分钟前
JSON-Server 极速入门教程
前端
确实菜,真的爱36 分钟前
用css画一条弧线
前端·css
bingbingyihao1 小时前
vue拓扑图组件
前端·javascript·vue.js
广龙宇1 小时前
【Web API系列】XMLHttpRequest API和Fetch API深入理解与应用指南
前端
cjxIt1 小时前
element-ui 中的 select 组件如何 remote-method 函数中传参
javascript·vue.js·ui
BillKu1 小时前
Vue3 + TypeScript 的 Hooks 实用示例
前端·vue.js·typescript