繁体   English   中英

动态设置Prop键JSX

[英]Set Prop Key Dynamically JSX

我想知道是否有可能在JSX中执行以下操作(此代码不起作用,只是我正在尝试做的一个示例):

const propKey = 'someProp';
const jsx = <MyComponent [propKey]="some value" />;
// evaluates to <MyComponent someProp="some value">

我正在使用babel es2015 stage-1,所以我可以像这样传播一个字典:

const extraProps = {[propKey]: 'some value'};
const jsx = <MyComponent {...extraProps} />

但对于一个道具来说,这似乎太笨重了。 我不打算使用React.createElement; 我所有的课程都是es6课程。 谢谢!

您可以使用计算的属性名称在JSX中创建一个对象,并将其传播:

const propKey = 'someProp';
const jsx = <MyComponent { ...{ [propKey]: "some value" } } />;

JSX是用于调用React.createElement语法糖。 所以一种解决方案是直接调用React.createElement

const element = React.createElement(MyComponent, {[propKey]: 'some value'});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM