Vue3子组件向父组件传值的两种实现方式

 更新时间:2024年04月11日 09:05:22   作者:thonmsneee98  
近期学习vue3的父子组件之间的传值,发现跟vue2的并没有太大的区别,这篇文章主要给大家介绍了关于Vue3子组件向父组件传值的两种实现方式,文中通过代码介绍的非常详细,需要的朋友可以参考下

有两种方式可以实现。

方式一:

父组件传送一个处理方法给子组件,子组件调用这个处理方法把父组件关心的值作为参数传给这个处理方法。

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

<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>
    	# 当button被按下时,子组件里的request变量内容就会传给父组件的处理方法
      <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)
  # 父组件把子组件传过来的值放在了自己内部变量数组里
  subRequests.value.push(request)
}
</script>

方式二:子组件发送emit方法给父组件

例子在子组件里,就两步要做:1. 定义emits事件,2,在想要的时机发送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>()
# 定义要发送的emit事件
const emit = defineEmits(['dropDownValueChange'])
const selectedValue = ref(props.title)

const click = (theType: string) => {
  console.log('clicked', theType)
  selectedValue.value = theType
  # 发送事件,theType就是发送出去的值
  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>

这两种方法我都在自己代码里用过了,亲测可用。优不优雅就另说了,先能用再说吧

总结

到此这篇关于Vue3子组件向父组件传值的两种实现方式的文章就介绍到这了,更多相关Vue3子组件向父组件传值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue3引入SVG图标的流程步骤

    Vue3引入SVG图标的流程步骤

    我们在开发 Vue 项目的时候会使用一些前端组件库,例如 Element、Ant Design 等,这些组件库虽然方便,但是也有一些缺点,比如内置的图标太少,例如我们开发医疗、财务、工程等一些前端项目,内置的图标不能满足我们的需求,所以我们常常在Vue项目中引入SVG图标
    2024-09-09
  • Vue中的同步和异步调用顺序详解

    Vue中的同步和异步调用顺序详解

    这篇文章主要介绍了Vue中的同步和异步调用顺序,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • vue中使用echarts并根据选择条件动态展示echarts图表

    vue中使用echarts并根据选择条件动态展示echarts图表

    虽然老早就看过很多echarts的例子, 但自己接触的项目中一直都没有真正用到过,直到最近才开始真正使用,下面这篇文章主要给大家介绍了关于vue中使用echarts并根据选择条件动态展示echarts图表的相关资料,需要的朋友可以参考下
    2023-12-12
  • element-ui中按需引入的实现

    element-ui中按需引入的实现

    这篇文章主要介绍了element-ui中按需引入的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • vue使用cesium创建数据白模方式

    vue使用cesium创建数据白模方式

    这篇文章主要介绍了vue使用cesium创建数据白模方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • vue移动端时弹出侧边抽屉菜单效果

    vue移动端时弹出侧边抽屉菜单效果

    这篇文章主要介绍了vue移动端时弹出侧边抽屉菜单,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 在Vue3中使用CodeMirror插件的方法详解

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

    CodeMirror是一个功能强大的Web代码编辑器,广泛应用于各种Web应用中,在Vue3项目中集成CodeMirror,可以显著提升代码编辑和展示的用户体验,本文将结合实际案例,详细介绍在Vue3中使用CodeMirror插件的方法,需要的朋友可以参考下
    2024-12-12
  • vue实现拖拽或点击上传图片

    vue实现拖拽或点击上传图片

    这篇文章主要为大家详细介绍了vue实现拖拽或点击上传图片,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 基于Vue实现文件拖拽上传功能

    基于Vue实现文件拖拽上传功能

    文件拖拽上传功能现在已经随处可见,大家应该都用过了吧,那么它具体是怎么实现的大家有去了解过吗,今天我们一起来实现一下这个功能,并封装一个拖拽上传组件吧
    2024-03-03
  • Vue-cli3生成的Vue项目加载Mxgraph方法示例

    Vue-cli3生成的Vue项目加载Mxgraph方法示例

    这篇文章主要介绍了Vue-cli3生成的Vue项目加载Mxgraph方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05

最新评论