欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3子組件向父組件傳值的兩種實(shí)現(xiàn)方式

 更新時(shí)間:2024年04月11日 09:05:22   作者:thonmsneee98  
近期學(xué)習(xí)vue3的父子組件之間的傳值,發(fā)現(xiàn)跟vue2的并沒(méi)有太大的區(qū)別,這篇文章主要給大家介紹了關(guān)于Vue3子組件向父組件傳值的兩種實(shí)現(xiàn)方式,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

有兩種方式可以實(shí)現(xiàn)。

方式一:

父組件傳送一個(gè)處理方法給子組件,子組件調(diào)用這個(gè)處理方法把父組件關(guān)心的值作為參數(shù)傳給這個(gè)處理方法。

例子:================子組件 (父組件在下面)

<template>
  <el-form :inline="true" :model="request" class="demo-form-inline">
    <el-form-item>
      <target-type-drop-down />
    </el-form-item>
    <el-form-item>
      <include-type />
    </el-form-item>
    <el-form-item label="Include">
      <el-input v-model="request.number" placeholder="3" />
    </el-form-item>
    <el-form-item>
    	# 當(dāng)button被按下時(shí),子組件里的request變量?jī)?nèi)容就會(huì)傳給父組件的處理方法
      <el-button type="primary" @click="parentMethod(request)"
        >Generate Req</el-button
      >
    </el-form-item>
  </el-form>
</template>
<script lang="ts" setup>
import { ref } from 'vue'
import { subRequest } from '@cp/MyTypes'
const request = ref<subRequest>({number: 3});

# 定義從父組件接收的處理方法
defineProps({
  parentMethod: {
    type: Function,
    default: () => {},
  },
})

================父組件

<template>
	# 父組件傳送給子組件的處理方法
  <request-gen v-if="showGenFlag" :parentMethod="childValueHandlingMethod" />
</template>
<script lang="ts" setup>
import { ref } from 'vue'
import { subRequest } from '@cp/MyTypes'

const subRequests = ref<subRequest[]>([])

const childValueHandlingMethod = (request: subRequest) => {
  console.log('Hello I am from children component', request)
  # 父組件把子組件傳過(guò)來(lái)的值放在了自己內(nèi)部變量數(shù)組里
  subRequests.value.push(request)
}
</script>

方式二:子組件發(fā)送emit方法給父組件

例子在子組件里,就兩步要做:1. 定義emits事件,2,在想要的時(shí)機(jī)發(fā)送emits事件
================子組件 (父組件在下面)

<template>
  <el-dropdown class="margin-right">
    <el-button type="info">
      {{ selectedValue
      }}<el-icon class="el-icon--right"><arrow-down /></el-icon>
    </el-button>
    <template #dropdown>
      <el-dropdown-menu>
        <el-dropdown-item
          v-for="theType in items"
          :key="`${theType}`"
          @click="click(theType)"
          >{{ theType }}</el-dropdown-item
        >
      </el-dropdown-menu>
    </template>
  </el-dropdown>
</template>
<script lang="ts" setup>
import { computed, defineEmits, ref } from 'vue'
import { ToRef } from 'vue-demi'

interface Props {
  items: String[]
  title: String
}
const props = defineProps<Props>()
# 定義要發(fā)送的emit事件
const emit = defineEmits(['dropDownValueChange'])
const selectedValue = ref(props.title)

const click = (theType: string) => {
  console.log('clicked', theType)
  selectedValue.value = theType
  # 發(fā)送事件,theType就是發(fā)送出去的值
  emit('dropDownValueChange', theType)
}
</script>

================父組件

<template>
  <common-drop-down
    title="Fruits"
    :items="items"
    @dropDownValueChange="fruitValueChange"
  />
</template>
<script lang="ts" setup>
import { ToRef } from "vue-demi"

const items = ['Apple', 'Orange', 'Pineapple', 'Banana']
const fruitValueChange = (e: any): void => {
  console.log('in parent compoennt, e=', e)
}
</script>

這兩種方法我都在自己代碼里用過(guò)了,親測(cè)可用。優(yōu)不優(yōu)雅就另說(shuō)了,先能用再說(shuō)吧

總結(jié)

到此這篇關(guān)于Vue3子組件向父組件傳值的兩種實(shí)現(xiàn)方式的文章就介紹到這了,更多相關(guān)Vue3子組件向父組件傳值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3引入SVG圖標(biāo)的流程步驟

    Vue3引入SVG圖標(biāo)的流程步驟

    我們?cè)陂_(kāi)發(fā) Vue 項(xiàng)目的時(shí)候會(huì)使用一些前端組件庫(kù),例如 Element、Ant Design 等,這些組件庫(kù)雖然方便,但是也有一些缺點(diǎn),比如內(nèi)置的圖標(biāo)太少,例如我們開(kāi)發(fā)醫(yī)療、財(cái)務(wù)、工程等一些前端項(xiàng)目,內(nèi)置的圖標(biāo)不能滿足我們的需求,所以我們常常在Vue項(xiàng)目中引入SVG圖標(biāo)
    2024-09-09
  • Vue中的同步和異步調(diào)用順序詳解

    Vue中的同步和異步調(diào)用順序詳解

    這篇文章主要介紹了Vue中的同步和異步調(diào)用順序,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • vue中使用echarts并根據(jù)選擇條件動(dòng)態(tài)展示echarts圖表

    vue中使用echarts并根據(jù)選擇條件動(dòng)態(tài)展示echarts圖表

    雖然老早就看過(guò)很多echarts的例子, 但自己接觸的項(xiàng)目中一直都沒(méi)有真正用到過(guò),直到最近才開(kāi)始真正使用,下面這篇文章主要給大家介紹了關(guān)于vue中使用echarts并根據(jù)選擇條件動(dòng)態(tài)展示echarts圖表的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • element-ui中按需引入的實(shí)現(xiàn)

    element-ui中按需引入的實(shí)現(xiàn)

    這篇文章主要介紹了element-ui中按需引入的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • vue使用cesium創(chuàng)建數(shù)據(jù)白模方式

    vue使用cesium創(chuàng)建數(shù)據(jù)白模方式

    這篇文章主要介紹了vue使用cesium創(chuàng)建數(shù)據(jù)白模方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue移動(dòng)端時(shí)彈出側(cè)邊抽屜菜單效果

    vue移動(dòng)端時(shí)彈出側(cè)邊抽屜菜單效果

    這篇文章主要介紹了vue移動(dòng)端時(shí)彈出側(cè)邊抽屜菜單,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • 在Vue3中使用CodeMirror插件的方法詳解

    在Vue3中使用CodeMirror插件的方法詳解

    CodeMirror是一個(gè)功能強(qiáng)大的Web代碼編輯器,廣泛應(yīng)用于各種Web應(yīng)用中,在Vue3項(xiàng)目中集成CodeMirror,可以顯著提升代碼編輯和展示的用戶體驗(yàn),本文將結(jié)合實(shí)際案例,詳細(xì)介紹在Vue3中使用CodeMirror插件的方法,需要的朋友可以參考下
    2024-12-12
  • vue實(shí)現(xiàn)拖拽或點(diǎn)擊上傳圖片

    vue實(shí)現(xiàn)拖拽或點(diǎn)擊上傳圖片

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)拖拽或點(diǎn)擊上傳圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 基于Vue實(shí)現(xiàn)文件拖拽上傳功能

    基于Vue實(shí)現(xiàn)文件拖拽上傳功能

    文件拖拽上傳功能現(xiàn)在已經(jīng)隨處可見(jiàn),大家應(yīng)該都用過(guò)了吧,那么它具體是怎么實(shí)現(xiàn)的大家有去了解過(guò)嗎,今天我們一起來(lái)實(shí)現(xiàn)一下這個(gè)功能,并封裝一個(gè)拖拽上傳組件吧
    2024-03-03
  • Vue-cli3生成的Vue項(xiàng)目加載Mxgraph方法示例

    Vue-cli3生成的Vue項(xiàng)目加載Mxgraph方法示例

    這篇文章主要介紹了Vue-cli3生成的Vue項(xiàng)目加載Mxgraph方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05

最新評(píng)論