亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3中父子傳參常見方式及用法

 更新時(shí)間:2024年01月02日 14:50:16   作者:我胡為喜呀  
在 Vue 3 中,父子組件之間進(jìn)行通信有多種方式,下面簡單介紹下常見的方式及其用法和使用場(chǎng)景,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧

在 Vue 3 中,父子組件之間進(jìn)行通信有多種方式,下面簡單介紹下常見的方式及其用法和使用場(chǎng)景:

一、Props

用于父組件向子組件傳遞數(shù)據(jù)。
這是最基本也是最常用的一種方式。通過在子組件上定義 props,父組件可以將數(shù)據(jù)傳遞給子組件。在子組件中,通過 props 對(duì)象訪問這些屬性。
父組件

<template>
  <ChildComponent :message="parentMessage" />
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
  components: {
    ChildComponent,
  },
  data() {
    return {
      parentMessage: 'Hello from parent!',
    };
  },
};
</script>

子組件

<template>
  <div>{{ message }}</div>
</template>
<script>
export default {
  props: {
    message: String,
  },
};
</script>

二、v-model

用于在父子組件之間實(shí)現(xiàn)雙向綁定。在 Vue 3 中,通過 v-model 方式進(jìn)行組件通信需要使用 v-model 指令和 emit 事件。父組件使用 v-model 向子組件傳遞數(shù)據(jù),并通過子組件觸發(fā) ,用update:modelValue 事件來實(shí)現(xiàn)雙向綁定。
下面是一個(gè)簡單的例子:
子組件

<!-- ChildComponent.vue -->
<template>
  <input :value="message" @input="$emit('update:modelValue', $event)" />
</template>
<script>
export default {
  props: {
    modelValue: String,
  },
  computed: {
    message: {
      get() {
        return this.modelValue;
      },
      set(value) {
        this.$emit('update:modelValue', value);
      },
    },
  },
};
</script>

父組件

<!-- ParentComponent.vue -->
<template>
  <ChildComponent v-model="parentMessage" />
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
  components: {
    ChildComponent,
  },
  data() {
    return {
      parentMessage: 'Hello from parent!',
    };
  },
};
</script>

在子組件 ChildComponent 中,通過 :value=“modelValue” 將 modelValue 綁定到 input 元素上,然后通過 @input=“$emit(‘update:modelValue’, $event)” 觸發(fā) update:modelValue 事件,從而實(shí)現(xiàn)了父子組件之間的雙向綁定。

在父組件 ParentComponent 中,使用 v-model 將 ChildComponent 的 modelValue 綁定到 message 上,這樣在父組件中修改 message 的值會(huì)自動(dòng)同步到 ChildComponent 中,反之亦然。

需要注意的是,v-model 實(shí)際上是一個(gè)語法糖,它會(huì)自動(dòng)處理 value 和 input 事件。如果在子組件中使用 v-model,則子組件應(yīng)該接受名為 modelValue 的 prop,并發(fā)出一個(gè)名為 update:modelValue 的事件。這樣可以確保 v-model 在父子組件之間正確地進(jìn)行雙向綁定。

三、Provide/Inject:

用于祖先組件向后代組件傳遞數(shù)據(jù),通過 Provide 提供數(shù)據(jù),通過 Inject 注入數(shù)據(jù)。祖先組件通過 provide 提供數(shù)據(jù),后代組件通過 inject 接收數(shù)據(jù)。
祖先組件

<template>
  <GrandparentComponent>
    <template v-slot="{ message }">
      <ChildComponent :message="message" />
    </template>
  </GrandparentComponent>
</template>
<script>
import GrandparentComponent from './GrandparentComponent.vue';
export default {
  components: {
    GrandparentComponent,
  },
  provide() {
    return {
      message: 'Hello from grandparent!',
    };
  },
};
</script>

父組件

<template>
  <slot :message="message" />
</template>
<script>
export default {
  inject: ['message'],
};
</script>

子組件

<template>
  <div>{{ message }}</div>
</template>
<script>
export default {
  props: {
    message: String,
  },
};
</script>

四、事件

通過自定義事件,子組件向父組件傳遞數(shù)據(jù)。子組件通過 $emit 觸發(fā)自定義事件,父組件監(jiān)聽該事件接收數(shù)據(jù)。
子組件

<template>
  <button @click="sendMessage">Send Message</button>
</template>
<script>
export default {
  methods: {
    sendMessage() {
      this.$emit('message', 'Hello from child!');
    },
  },
};
</script>

父組件

<template>
  <ChildComponent @message="handleMessage" />
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
  components: {
    ChildComponent,
  },
  methods: {
    handleMessage(message) {
      console.log(message);
    },
  },
};
</script>

四、Ref

使用 ref 可以將數(shù)據(jù)在父子組件之間共享。
父組件

<template>
  <ChildComponent :message="sharedMessage" />
</template>
<script>
import { ref } from 'vue';
import ChildComponent from './ChildComponent.vue';
export default {
  components: {
    ChildComponent,
  },
  setup() {
    const sharedMessage = ref('Hello from parent!');
    return { sharedMessage };
  },
};
</script>

子組件

<template>
  <div>{{ message }}</div>
</template>
<script>
import { ref, watchEffect } from 'vue';
export default {
  props: {
    message: String,
  },
  setup(props) {
    const message = ref(props.message);
    watchEffect(() => {
      // 監(jiān)聽 props 中的 message 變化
      message.value = props.message;
    });
    return { message };
  },
};
</script>

到此這篇關(guān)于Vue3中父子傳參的文章就介紹到這了,更多相關(guān)Vue3父子傳參內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue封裝組件之上傳圖片組件

    vue封裝組件之上傳圖片組件

    這篇文章主要為大家詳細(xì)介紹了vue封裝組件之上傳圖片組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 淺談vue 多個(gè)變量同時(shí)賦相同值互相影響

    淺談vue 多個(gè)變量同時(shí)賦相同值互相影響

    這篇文章主要介紹了淺談vue 多個(gè)變量同時(shí)賦相同值互相影響,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue中nextTick的原理分析

    Vue中nextTick的原理分析

    本文詳細(xì)介紹了Vue中nextTick的原理和使用方法,Vue采用異步渲染機(jī)制,通過nextTick可以確保在DOM更新后執(zhí)行回調(diào),nextTick依賴微任務(wù)和宏任務(wù),優(yōu)先使用Promise,降級(jí)到MutationObserver/setTimeout,Vue3進(jìn)一步優(yōu)化了nextTick,減少了復(fù)雜度并提升了性能
    2025-02-02
  • vue中使用騰訊云Im的示例

    vue中使用騰訊云Im的示例

    這篇文章主要介紹了vue中使用騰訊云Im的示例,幫助大家調(diào)用對(duì)應(yīng)的api,完成自己的項(xiàng)目,感興趣的朋友可以了解下
    2020-10-10
  • vue自定義氣泡彈窗

    vue自定義氣泡彈窗

    這篇文章主要為大家詳細(xì)介紹了vue自定義氣泡彈窗,包含css晃動(dòng)動(dòng)畫shake制作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 解決Vue3?echarts?v-show無法重新渲染的問題

    解決Vue3?echarts?v-show無法重新渲染的問題

    這篇文章主要介紹了Vue3?echarts?v-show無法重新渲染的問題,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-09-09
  • 如何使用Vue3.2+Vite2.7從0快速打造一個(gè)UI組件庫

    如何使用Vue3.2+Vite2.7從0快速打造一個(gè)UI組件庫

    構(gòu)建工具使用vue3推薦的vite,下面這篇文章主要給大家介紹了關(guān)于如何使用Vue3.2+Vite2.7從0快速打造一個(gè)UI組件庫的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • 詳解nuxt sass全局變量(公共scss解決方案)

    詳解nuxt sass全局變量(公共scss解決方案)

    這篇文章主要介紹了詳解nuxt sass全局變量(公共scss解決方案),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • element UI upload組件上傳附件格式限制方法

    element UI upload組件上傳附件格式限制方法

    今天小編就為大家分享一篇element UI upload組件上傳附件格式限制方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue項(xiàng)目如何安裝引入使用Vant

    Vue項(xiàng)目如何安裝引入使用Vant

    Vant是一個(gè)專為移動(dòng)端設(shè)計(jì)的輕量級(jí)組件庫,自2017年開源以來,提供了Vue2、Vue3及多平臺(tái)版本支持,安裝Vant時(shí)需要注意版本兼容問題,Vue3項(xiàng)目應(yīng)安裝最新版Vant3,而Vue2項(xiàng)目則需安裝Vant2,安裝錯(cuò)誤時(shí),需卸載后重新安裝正確版本
    2024-10-10

最新評(píng)論