vue子组件修改父组件的值

一般来说,子组件不应该直接修改父组件的 props,因为这会违背 Vue 的单向数据流原则。

使用 ref 和 toRefs 修改父组件的值

子组件

js 复制代码
props = defineProps({
	searchParams: {
	    type: Object,
	    required: true
	  }
})

const { searchParams } = toRefs(props);

searchParams.value=xxx就可以直接修改父组件的值

const aaa = computed(() => {
  return props.searchParams
})
//这个是为了保证父组件的searchParams改变了后
//子组件能响应式接收到

此时,searchParams.value与props.searchParams是一样的引用,子组件可以直接修改 searchParams.value,修改会同步到父组件。

aaa =props.searchParams不可行的原因

//1、Vue 中的 props 是只读的,不能修改

//2、aaa中存放的只是props.searchParams的初始值,props.searchParams变化了,并不会通知aaa

子组件通过事件通知

在这种方式中,子组件通过 $emit 将数据的更新请求传递给父组件,父组件接收到事件后更新自己的状态。这是 Vue 中推荐的做法。

父组件

js 复制代码
<child @update="updateParams">

updateParams(newParams){
	this.params = newParams
}

子组件

js 复制代码
this.$emit("update",this.localParams)

v-model 双向绑定(父组件控制数据,子组件自动更新)【没看懂,最繁琐的一种方式】

父组件

js 复制代码
<template>
  <ChildComponent v-model="searchParams" />
</template>

<script setup lang="ts">
import { ref } from 'vue';
import ChildComponent from './ChildComponent.vue';

// 父组件的数据 searchParams
const searchParams = ref({ term: '' });
</script>

子组件

js 复制代码
<template>
  <!-- 简化为直接使用 localModel 进行 v-model 绑定 -->
  <el-input v-model="localModel.term" placeholder="请输入内容" />
</template>

<script setup lang="ts">
import { computed } from 'vue';
import { defineProps, defineEmits } from 'vue';

// 接收父组件传递的 modelValue 作为 props
const props = defineProps({
  modelValue: {
    type: Object,
    required: true
  }
});

// 定义 emits 用于传递更新给父组件
const emit = defineEmits(['update:modelValue']);

// 使用 computed 创建双向绑定的属性
const localModel = computed({
  get() {
    return props.modelValue; // 获取父组件传递的数据
  },
  set(value) {
    emit('update:modelValue', value); // 当 localModel 改变时,向父组件发送更新
  }
});
</script>
相关推荐
开开心心就好1 天前
近200个工具的电脑故障修复合集
安全·智能手机·pdf·电脑·consul·memcache·1024程序员节
数据皮皮侠AI3 天前
中国城市可再生能源数据集(2005-2021)|顶刊 Sci Data 11 种能源面板
大数据·人工智能·笔记·能源·1024程序员节
计算机毕业论文辅导6 天前
物联网实战:基于MQTT协议的智能家居数据传输系统设计与实现
1024程序员节
开开心心就好6 天前
支持批量处理的视频分割工具推荐
安全·智能手机·rust·pdf·电脑·1024程序员节·lavarel
liuyao_xianhui8 天前
Linux开发工具结尾 _make
linux·运维·服务器·数据结构·哈希算法·宽度优先·1024程序员节
学传打活10 天前
【边打字.边学昆仑正义文化】_21_爱的结晶(1)
微信公众平台·1024程序员节·汉字·昆仑正义文化
数据皮皮侠AI17 天前
顶刊同款!中国地级市风灾风险与损失数据集(2000-2022)|灾害 / 环境 / 经济研究必备
大数据·人工智能·笔记·能源·1024程序员节
Fab1an18 天前
Busqueda——Hack The Box 靶机
linux·服务器·学习·1024程序员节
技术专家19 天前
Stable Diffusion系列的详细讨论 / Detailed Discussion of the Stable Diffusion Series
人工智能·python·算法·推荐算法·1024程序员节
学传打活21 天前
古代汉语是源,现代汉语是流,源与流一脉相承。
微信公众平台·1024程序员节·汉字·中华文化