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

Vue.js?中的父子組件通信方式實例教程

 更新時間:2023年09月27日 09:59:49   作者:stormjun  
在 Vue.js 中,父子組件通信是非常重要的,在本文中,我們討論了 Vue.js 中父子組件通信的幾種方式,包括使用 props 傳遞數(shù)據(jù)、使用 Sync 修飾符實現(xiàn)雙向綁定、使用自定義事件傳遞數(shù)據(jù)、使用 $refs 訪問子組件實例以及使用 $children 和 $parent 訪問父子組件實例

Vue.js 中的父子組件通信方式

在 Vue.js 中,組件是構(gòu)建應(yīng)用程序的基本單元。當(dāng)我們在應(yīng)用程序中使用組件時,組件之間的通信是非常重要的。在 Vue.js 中,父子組件通信是最常見的組件通信方式之一。在本文中,我們將討論 Vue.js 中的父子組件通信方式,并附上代碼實例。

在這里插入圖片描述

父組件向子組件傳遞數(shù)據(jù)

Props

props 是 Vue.js 中父組件向子組件傳遞數(shù)據(jù)的一種方式。通過 props,父組件可以向子組件傳遞任何類型的數(shù)據(jù),包括字符串、數(shù)字、對象、數(shù)組等等。在子組件中,props 是只讀的,不能直接修改,只能通過事件的方式向父組件發(fā)送數(shù)據(jù)。

下面是一個使用 props 傳遞數(shù)據(jù)的示例:

<!-- 父組件 -->
<template>
  <div>
    <my-child :message="parentMessage"></my-child>
  </div>
</template>
<script>
import MyChild from './MyChild.vue';
export default {
  components: {
    MyChild,
  },
  data() {
    return {
      parentMessage: '這是來自父組件的消息',
    };
  },
};
</script>
<!-- 子組件 -->
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>
<script>
export default {
  props: {
    message: String,
  },
};
</script>

在上面的示例中,父組件通過 props 將 parentMessage 傳遞給子組件 MyChild ,并將其命名為 message 。在子組件中,我們可以通過 props 對象來聲明 message 屬性,然后在模板中使用它來渲染數(shù)據(jù)。

Sync 修飾符

除了 props 之外,Vue.js 還提供了一個 Sync 修飾符,可以通過它來實現(xiàn)雙向數(shù)據(jù)綁定。Sync 修飾符實際上是一個語法糖,它將父組件向子組件傳遞數(shù)據(jù)和子組件向父組件發(fā)送數(shù)據(jù)的操作包裝在一起。

下面是一個使用 Sync 修飾符的示例:

<!-- 父組件 -->
<template>
  <div>
    <my-child :message.sync="parentMessage"></my-child>
  </div>
</template>
<script>
import MyChild from './MyChild.vue';
export default {
  components: {
    MyChild,
  },
  data() {
    return {
      parentMessage: '這是來自父組件的消息',
    };
  },
};
</script>
<!-- 子組件 -->
<template>
  <div>
    <input v-model="message" @input="$emit('update:message', message)" />
  </div>
</template>
<script>
export default {
  props: {
    message: String,
  },
};
</script>

在上面的示例中,父組件通過 :message.sync parentMessage 傳遞給子組件 MyChild ,并使用 v-model 指令將子組件的 message 屬性與一個輸入框進行雙向綁定。在子組件中,我們使用 @input 事件將輸入框的值發(fā)送給父組件,實現(xiàn)雙向數(shù)據(jù)綁定。

子組件向父組件傳遞數(shù)據(jù)

自定義事件

除了 props 之外,子組件還可以通過自定義事件向父組件傳遞數(shù)據(jù)。在子組件中,我們可以使用 $emit 方法觸發(fā)一個自定義事件,并將數(shù)據(jù)作為參數(shù)傳遞給父組件。父組件可以通過 v-on 指令監(jiān)聽子組件的自定義事件,并在事件處理函數(shù)中獲取子組件傳遞的數(shù)據(jù)。

下面是一個使用自定義事件傳遞數(shù)據(jù)的示例:

<!-- 父組件 -->
<template>
  <div>
    <my-child @child-click="handleChildClick"></my-child>
  </div>
</template>
<script>
import MyChild from './MyChild.vue';
export default {
  components: {
    MyChild,
  },
  methods: {
    handleChildClick(data) {
      console.log('從子組件傳遞過來的數(shù)據(jù):', data);
    },
  },
};
</script>
<!-- 子組件 -->
<template>
  <div>
    <button @click="handleClick">點擊我向父組件傳遞數(shù)據(jù)</button>
  </div>
</template>
<script>
export default {
  methods: {
    handleClick() {
      this.$emit('child-click', '這是來自子組件的消息');
    },
  },
};
</script>

在上面的示例中,子組件 MyChild 中定義了一個按鈕,并在按鈕的 click 事件中觸發(fā)了一個自定義事件 child-click ,并將數(shù)據(jù) '這是來自子組件的消息' 作為參數(shù)傳遞給父組件。父組件通過 @child-click 指令監(jiān)聽子組件的自定義事件,并在事件處理函數(shù)中打印子組件傳遞的數(shù)據(jù)。

$refs

除了自定義事件之外,子組件還可以通過 $refs 屬性來訪問父組件,從而向父組件傳遞數(shù)據(jù)。在父組件中,我們可以通過 ref 屬性給子組件命名,然后在父組件中通過 $refs 屬性訪問子組件實例,并調(diào)用子組件中的方法或訪問子組件中的數(shù)據(jù)。

下面是一個使用 $refs 傳遞數(shù)據(jù)的示例:

<!-- 父組件 -->
<template>
  <div>
    <my-child ref="child"></my-child>
    <button @click="handleClick">點擊我向子組件傳遞數(shù)據(jù)</button>
  </div>
</template>
<script>
import MyChild from './MyChild.vue';
export default {
  components: {
    MyChild,
  },
  methods: {
    handleClick() {
      this.$refs.child.handleParentClick('這是來自父組件的消息');
    },
  },
};
</script>
<!-- 子組件 -->
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: '',
    };
  },
  methods: {
    handleParentClick(data) {
      this.message = data;
    },
  },
};
</script>

在上面的示例中,父組件中通過 ref 屬性給子組件命名為 child 。在父組件中,我們通過 $refs.child 訪問 MyChild 組件實例,并調(diào)用子組件中的 handleParentClick 方法,將數(shù)據(jù) '這是來自父組件的消息' 傳遞給子組件。在子組件中,我們將傳遞過來的數(shù)據(jù)賦值給 message 屬性,然后在模板中渲染出來。

父子組件之間的訪問

在 Vue.js 中,父組件可以通過 $children 屬性訪問它的所有子組件實例,而子組件可以通過 $parent 屬性訪問它的父組件實例。

下面是一個示例:

<!-- 父組件 -->
<template>
  <div>
    <my-child></my-child>
    <my-child></my-child>
    <button @click="handleClick">點擊我訪問子組件</button>
  </div>
</template>
<script>
import MyChild from './MyChild.vue';
export default {
  components: {
    MyChild,
  },
  methods: {
    handleClick() {
      console.log(this.$children);
    },
  },
};
</script>
<!-- 子組件 -->
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>
<script>
export default {
  data() {
    return {
      message: '這是來自子組件的消息',
    };
  },
  created() {
    console.log(this.$parent);
  },
};
</script>

在上面的示例中,父組件中定義了兩個子組件 MyChild 。在父組件中,我們通過 $children 屬性訪問所有子組件,并在點擊按鈕時打印所有子組件實例。在子組件中,我們在 created 鉤子函數(shù)中訪問了父組件實例,并在模板中渲染出了一個消息。

總結(jié)

在 Vue.js 中,父子組件通信是非常重要的。在本文中,我們討論了 Vue.js 中父子組件通信的幾種方式,包括使用 props 傳遞數(shù)據(jù)、使用 Sync 修飾符實現(xiàn)雙向綁定、使用自定義事件傳遞數(shù)據(jù)、使用 $refs 訪問子組件實例以及使用 $children $parent 訪問父子組件實例。這些技術(shù)可以幫助我們更好地組織和管理應(yīng)用程序中的組件,并提高組件之間的交互性。

在實際開發(fā)中,我們可以根據(jù)具體的業(yè)務(wù)需求選擇合適的技術(shù)來實現(xiàn)父子組件通信。如果需要向子組件傳遞靜態(tài)數(shù)據(jù),可以使用 props;如果需要實現(xiàn)雙向數(shù)據(jù)綁定,可以使用 Sync 修飾符;如果需要向父組件傳遞數(shù)據(jù),可以使用自定義事件;如果需要訪問子組件實例,可以使用 $refs ,如果需要訪問父子組件實例,可以使用 $children $parent 。

在下面的代碼示例中,我們將展示如何使用 props、自定義事件和 $refs 這三種方式實現(xiàn)父子組件之間的通信。

<!-- 父組件 -->
<template>
  <div>
    <my-child :message="parentMessage" @child-click="handleChildClick" ref="child"></my-child>
    <button @click="handleClick">點擊我向子組件傳遞數(shù)據(jù)</button>
  </div>
</template>
<script>
import MyChild from './MyChild.vue';
export default {
  components: {
    MyChild,
  },
  data() {
    return {
      parentMessage: '這是來自父組件的消息',
    };
  },
  methods: {
    handleChildClick(data) {
      console.log('從子組件傳遞過來的數(shù)據(jù):', data);
    },
    handleClick() {
      this.$refs.child.handleParentClick('這是來自父組件的消息');
    },
  },
};
</script>
<!-- 子組件 -->
<template>
  <div>
    <p>{{ message }}</p>
    <button @click="handleClick">點擊我向父組件傳遞數(shù)據(jù)</button>
  </div>
</template>
<script>
export default {
  props: {
    message: String,
  },
  methods: {
    handleClick() {
      this.$emit('child-click', '這是來自子組件的消息');
    },
    handleParentClick(data) {
      console.log('從父組件傳遞過來的數(shù)據(jù):', data);
    },
  },
};
</script>

在上面的示例中,父組件通過 props 向子組件傳遞數(shù)據(jù),并在子組件中使用自定義事件向父組件傳遞數(shù)據(jù)。同時,父組件還使用 $refs 屬性訪問子組件實例,并調(diào)用子組件中的方法,向子組件傳遞數(shù)據(jù)。

到此這篇關(guān)于Vue.js 中的父子組件通信方式的文章就介紹到這了,更多相關(guān)Vue.js 父子組件通信內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Vue 2.0封裝axios筆記

    詳解Vue 2.0封裝axios筆記

    本篇文章主要介紹了詳解Vue 2.0封裝axios筆記,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • vue-cli+axios實現(xiàn)文件上傳下載功能(下載接收后臺返回文件流)

    vue-cli+axios實現(xiàn)文件上傳下載功能(下載接收后臺返回文件流)

    這篇文章主要介紹了vue-cli+axios實現(xiàn)文件上傳下載功能(下載接收后臺返回文件流),本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • Vue+Openlayer批量設(shè)置閃爍點的實現(xiàn)代碼(基于postrender機制)

    Vue+Openlayer批量設(shè)置閃爍點的實現(xiàn)代碼(基于postrender機制)

    本篇文章給大家介紹基于postrender機制使用Vue+Openlayer批量設(shè)置閃爍點的實現(xiàn)代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-09-09
  • vue實現(xiàn)單點登錄的方式匯總

    vue實現(xiàn)單點登錄的方式匯總

    最近項目停工了,RageFrame的學(xué)習(xí)暫時告一段落,這一篇給大家分享下有關(guān)單點登錄的相關(guān)知識,并提供一些demo給大家參考,對vue單點登錄的實現(xiàn)方式感興趣的朋友一起看看吧
    2021-11-11
  • Vue中添加滾動事件設(shè)置的方法詳解

    Vue中添加滾動事件設(shè)置的方法詳解

    這篇文章主要給大家介紹了關(guān)于Vue中添加滾動事件設(shè)置的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • vue實現(xiàn)分割驗證碼效果

    vue實現(xiàn)分割驗證碼效果

    這篇文章主要為大家詳細介紹了vue實現(xiàn)分割驗證碼效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue3?+?Ant?Design?實現(xiàn)雙表頭表格的效果(橫向表頭+縱向表頭)

    vue3?+?Ant?Design?實現(xiàn)雙表頭表格的效果(橫向表頭+縱向表頭)

    這篇文章主要介紹了vue3?+?Ant?Design?實現(xiàn)雙表頭表格(橫向表頭+縱向表頭),需要的朋友可以參考下
    2023-12-12
  • 利用Vue3 (一)創(chuàng)建Vue CLI 項目

    利用Vue3 (一)創(chuàng)建Vue CLI 項目

    這篇文章主要介紹利用Vue3 創(chuàng)建Vue CLI 項目,下面文章內(nèi)容附有官方文檔鏈接,安裝過程,需要的可以參考一下
    2021-10-10
  • 基于vue3&element-plus的暗黑模式實例詳解

    基于vue3&element-plus的暗黑模式實例詳解

    實現(xiàn)暗黑主題的方式有很多種,也有很多成型的框架可以直接使用,下面這篇文章主要給大家介紹了關(guān)于基于vue3&element-plus的暗黑模式的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • vue路由中前進后退的一些事兒

    vue路由中前進后退的一些事兒

    這篇文章主要給大家介紹了關(guān)于vue路由中前進后退的一些事兒,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用vue路由具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05

最新評論