Vue 3 中,组件间传值有多种方式

父组件向子组件传值(通过 props):

<!-- 父组件 -->
<template>
  <ChildComponent :message="parentMessage" />
</template>

<script setup>
import ChildComponent from './ChildComponent.vue';
const parentMessage = '这是来自父组件的值';
</script>

<!-- 子组件 -->
<template>
  <div>{{ message }}</div>
</template>

<script setup>
defineProps(['message']);
</script>

以下是几个父组件向子组件传值的示例:

示例 1:传递字符串

父组件:

<template>
  <ChildComponent :message="messageFromParent" />
</template>

<script setup>
import ChildComponent from './ChildComponent.vue';
const messageFromParent = '这是来自父组件的消息';
</script>

子组件:

<template>
  <div>{{ message }}</div>
</template>

<script setup>
defineProps(['message']);
</script>
示例 2:传递数字

父组件:

<template>
  <ChildComponent :count="5" />
</template>

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

子组件:

<template>
  <div>接收到的数字: {{ count }}</div>
</template>

<script setup>
defineProps(['count']);
</script>
示例 3:传递对象

父组件:

<template>
  <ChildComponent :userInfo="{ name: '张三', age: 25 }" />
</template>

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

子组件:

<template>
  <div>用户信息: {{ userInfo.name }}, {{ userInfo.age }}</div>
</template>

<script setup>
defineProps(['userInfo']);
</script>
示例 4:传递数组

父组件:

<template>
  <ChildComponent :fruits="['苹果', '香蕉', '橙子']" />
</template>

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

子组件:

<template>
  <div>水果列表: 
    <ul>
      <li v-for="fruit in fruits" :key="fruit">{{ fruit }}</li>
    </ul>
  </div>
</template>

<script setup>
defineProps(['fruits']);
</script>
示例 5:传递布尔值

父组件:

<template>
  <ChildComponent :isActive="true" />
</template>

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

子组件:

<template>
  <div v-if="isActive">当前状态为活跃</div>
  <div v-else>当前状态为不活跃</div>
</template>

<script setup>
defineProps(['isActive']);
</script>

子组件向父组件传值(通过自定义事件):

<!-- 父组件 -->
<template>
  <ChildComponent @childEvent="handleChildEvent" />
</template>

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

function handleChildEvent(valueFromChild) {
  console.log('从子组件接收到的值:', valueFromChild);
}
</script>

<!-- 子组件 -->
<template>
  <button @click="emitEvent">向父组件传值</button>
</template>

<script setup>
defineEmits(['childEvent']);

function emitEvent() {
  const valueToSend = '这是来自子组件的值';
  emit('childEvent', valueToSend);
}
</script>

子组件使用 v-model 向父组件传值的示例代码:

父组件:
html
复制

父组件接收到的值: {{ inputValue }}

子组件:
html
复制

<input type=“text” :value=“value” @input=“$emit(‘update:value’, $event.target.value)” />

在上述示例中,父组件通过 v-model:value=“inputValue” 将 inputValue 与子组件进行绑定。子组件中的输入框的值通过 :value=“value” 与父组件传来的值进行关联,当输入框的值发生变化时,通过 @input=“$emit(‘update:value’, $event.target.value)” 触发 update:value 事件并将新的值传递给父组件,从而实现子组件向父组件传值。

通过 provide 和 inject:

<!-- 父组件 -->
<template>
  <ChildComponent />
</template>

<script setup>
import { provide } from 'vue';

provide('sharedValue', '这是共享的值');
</script>

<!-- 子组件 -->
<template>
  <div>{{ sharedValue }}</div>
</template>

<script setup>
import { inject } from 'vue';

const sharedValue = inject('sharedValue');
</script>

使用 Vuex 状态管理:
首先安装 vuex :npm install vuex@next --save
创建一个 store.js 文件:

import { createStore } from 'vuex';

export default createStore({
  state: {
    commonValue: '这是全局的值',
  },
  mutations: {
    updateCommonValue(state, newValue) {
      state.commonValue = newValue;
    }
  },
  actions: {},
  getters: {}
});

在父组件和子组件中使用:

<!-- 父组件或子组件 -->
<template>
  <div>{{ $store.state.commonValue }}</div>
</template>

<script setup>
import { useStore } from 'vuex';

const store = useStore();

function updateValue() {
  store.commit('updateCommonValue', '新的值');
}
</script>

这些是 Vue 3 中常见的组件间传值方式,您可以根据具体的项目需求选择合适的方法。

### Vue3 组件间与监听 #### 使用 `props` 和 `$emit` 父组件可以通过定义属性来向子组件递数据。这些属性被称为 `props`。当需要从子组件触发事件通知父组件时,则可以使用 `$emit` 方法。 ```html <!-- ParentComponent.vue --> <template> <div> <!-- 向 ChildComponent 递 message 属性 --> <ChildComponent :message="parentMessage" @childEvent="handleChildEvent"/> </div> </template> <script setup> import { ref } from &#39;vue&#39;; const parentMessage = ref(&#39;Hello, child!&#39;); function handleChildEvent(data){ console.log(`Received data from child component: ${data}`); } </script> ``` ```html <!-- ChildComponent.vue --> <template> <button @click="sendMessageToParent">Send Message to Parent</button> </template> <script setup> defineProps([&#39;message&#39;]); function sendMessageToParent(){ defineEmits()(&#39;childEvent&#39;, &#39;Data sent by the child&#39;); } </script> ``` 此方法适用于父子关系中的单向数据流[^1]。 #### 使用 `v-model` 对于双向绑定场景,比如表单项,默认情况下可以用 `v-model` 来简化输入框和其他控件的数据同步操作。 ```html <!-- ParentComponent.vue --> <template> <input v-model="searchText"> <CustomInput v-model="searchText"></CustomInput> </template> <script setup> import CustomInput from &#39;./components/CustomInput.vue&#39; import {ref} from "vue"; let searchText = ref(&#39;&#39;); </script> ``` ```html <!-- CustomInput.vue --> <template> <input type="text" :value="modelValue" @input="$emit(&#39;update:modelValue&#39;, $event.target.value)"> </template> <script setup> defineProps({ modelValue: String, }); </script> ``` 这种方式使得自定义组件能够像内置元素一样支持 `v-model`[^2]。 #### 使用 `provide` / `inject` 如果多个嵌套层次的组件都需要访问相同的状态或函数,那么通过 `provide` 提供者模式可以在祖先组件中声明资源,在后代组件里注入并消费它们。 ```javascript // App.vue (Ancestor Component) export default { provide () { return { sharedState: this.sharedState, updateSharedState: this.updateSharedState } }, methods:{ updateSharedState(newValue){ this.sharedState=newValue; } } }; ``` ```javascript // AnyDescendant.vue (Any Descendant Component) export default { inject: [&#39;sharedState&#39;,&#39;updateSharedState&#39;], mounted(){ console.log(this.sharedState); } }; ``` 这允许跨多层组件共享状态而无需逐级递参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值