什么是...
在这个做反应(使用JSX)代码,什么是它叫什么名字?
<Modal {...this.props} title="Modal heading" animation={false}>
那是 财产传播符号
。它是在ES2018中添加的(用于数组/可迭代对象的版本早于ES2015),但是它在React项目中已经通过翻译长期得到支持(“
JSX传播属性
”,即使您也可以在其他地方这样做) )。
{...this.props}
将 “自己的”可枚举属性props
作为离散属性 散布
在Modal
要创建的元素上。例如,如果this.props
包含a: 1
和b: 2
,则
<Modal {...this.props} title="Modal heading" animation={false}>
将与
<Modal a={this.props.a} b={this.props.b} title="Modal heading" animation={false}>
但是它是动态的,因此包括了所有“自有”属性props
。
由于children
是中的“拥有”属性props
,因此传播将包括它。因此,如果出现此内容的组件具有子元素,则将它们传递给Modal
。在开始标签和结束标签之间放置子元素只是语法上的糖-
一种children
在开始标签中放置属性的好方法。例:
class Example extends React.Component {
render() {
const { className, children } = this.props;
return (
<div className={className}>
{children}
</div>
);
}
}
ReactDOM.render(
[
<Example className="first">
<span>Child in first</span>
</Example>,
<Example className="second" children={<span>Child in second</span>} />
],
document.getElementById("root")
);
.first {
color: green;
}
.second {
color: blue;
}
<div id="root"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
扩展符号不仅适用于该用例,而且对于创建具有现有对象的大多数(或全部)属性的新对象非常方便-在更新状态时会遇到很多问题,因为您无法修改状态直:
this.setState(prevState => {
return {foo: {...prevState.foo, a: "updated"}};
});
该this.state.foo
属性将替换为具有与该属性相同的所有属性的新对象,foo
该a
属性变为"updated"
:
const obj = {
foo: {
a: 1,
b: 2,
c: 3
}
};
console.log("original", obj.foo);
// Creates a NEW object and assigns it to `obj.foo`
obj.foo = {...obj.foo, a: "updated"};
console.log("updated", obj.foo);
.as-console-wrapper {
max-height: 100% !important;
}
问题内容: 什么是在这个做反应(使用JSX)代码,什么是它叫什么名字? 问题答案: 那是 property spread notation。它是在ES2018中添加的(用于数组/可迭代对象的版本更早于ES2015),但是随着时间的流逝,它通过转译得到了支持(作为“ JSX spread attributes ”,即使你也可以在其他地方这样做,而不仅仅是属性) 。 将 “自己的”可枚举属性作为离散属
在这个React(使用JSX)代码中做什么,它叫什么?
“{...X}”这个代码是什么意思?
当我安装Magento 2在我的服务器上,我得到了一个错误。经过对代码的调查,发现有三个点(),这是产生错误的。我包含了我在下面找到的代码:
不懂的问题。我有一个chrome扩展,当它访问一个API时,它会返回一些奇怪的结果。 我认为问题出在从DOM中提取的用户ID上。 这些元素的目的究竟是什么? 为什么它们末尾的一些ID是相同的,而另一些ID却是不同的呢?
本文向大家介绍react是什么?它的主要特点是什么?相关面试题,主要包含被问及react是什么?它的主要特点是什么?时的应答技巧和注意事项,需要的朋友参考一下 react 是一个用于构建用户UI界面的js库,通过虚拟dom和diff算法 最大减少dom操作,提升性能