【避坑】React 框架下 props.value 无法传递

避免Props值冲突
本文探讨了在React中使用props传递值时遇到的问题,当尝试通过props.value传递数据时出现了未定义的情况。通过调整key名称成功解决了该问题。

问题描述

利用 props 向元素传递 value 值:

const Element1 = () => {
	return <Element2 value="something" />;
}

调用 value:

const Element2 = (props) => {
	console.log(props.value);
	return <div />;
}

发现结果为 undefined,而不是预期的 something.

定位问题

调用 props:

const Element2 = (props) => {
	console.log(props);
	return <div />;
}

结果为:

{
	id: "nest-messages_LocationDesc"
	onChange: ƒ ()
	value: undefined
	[[Prototype]]: Object
}

因此 props 组件正常地传递了,只是 props.value 出了问题。

尝试使用不同的 key 传递:

const Element1 = () => {
	return <Element2 someKey="something" />;
}

调用 someKey:

const Element2 = (props) => {
	console.log(props.someKey);
	return <div />;
}

结果为:

{
	someKey: "something"
	id: "nest-messages_LocationDesc"
	onChange: ƒ ()
	value: undefined
	[[Prototype]]: Object
}

因此笔者推测,props 预留了 value 字段,因此传递 props.value 会出现问题。

解决方法

不要使用 props.value,使用一个别的名字。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值