什么是…在这个React(使用JSX)代码中做什么,它被称为什么?
<Modal {...this.props} title='Modal heading' animation={false}>
什么是…在这个React(使用JSX)代码中做什么,它被称为什么?
<Modal {...this.props} title='Modal heading' animation={false}>
当前回答
这就是属性展开符号。它是在ES2018年添加的(扩展数组/可迭代对象是更早的ES2015年),但它在React项目中已经通过编译(作为“JSX扩展属性”,尽管你也可以在其他地方做,而不仅仅是属性)得到了很长时间的支持。
{……。props}将props中的“自己的”可枚举属性展开为您正在创建的Modal元素上的离散属性。例如,如果这个。道具包含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}>
但它是动态的,所以道具中任何“自己的”属性都包括在内。
由于儿童是道具中“自己”的属性,传播将包括它。如果这个出现的组件有子元素,它们会被传递给Modal。在开始标记和结束标记之间放置子元素只是语法上的“糖”——好的那种——用于在开始标记中放置子属性。例子:
实例扩展React。组件{ 呈现(){ const {className, children} = this.props; 回报( < div className = {className} > {孩子} < / div > ); } } ReactDOM.render ( [ > <例子className =“第一” <span>第一个子元素</span> < / >示例, <示例className="second" children={<span> second中的子</span>} /> ), . getelementbyid(“根”) ); 当代{ 颜色:绿色; } 接着{ 颜色:蓝色; } < div id = "根" > < / div > < script src = " https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js " > < /脚本> < script src = " https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js " > < /脚本>
扩展表示法不仅在这个用例中很方便,而且在创建一个具有现有对象的大部分(或全部)属性的新对象时也很方便——当你更新状态时经常会出现这种情况,因为你不能直接修改状态:
this.setState(prevState => {
return {foo: {...prevState.foo, a: "updated"}};
});
这将this.state.foo替换为一个新对象,该对象具有与foo相同的所有属性,除了a属性,它变成了“updated”:
Const obj = { foo: { 答:1, b: 2 c: 3 } }; console.log(“原始”,obj.foo); //创建一个新对象并将其赋值给' obj.foo ' obj。Foo ={…Foo, a: "updated"}; obj.foo console.log(“更新”); .as-console-wrapper { Max-height: 100%重要; }
其他回答
这三个点(…)被称为展开运算符,这在概念上类似于ES6数组展开运算符JSX 利用这些支持并开发标准,以便在JSX中提供更清晰的语法
对象初始化器中的展开属性复制自己的枚举对象 属性从提供的对象转移到新创建的对象。 设n = {x, y,…z}; n;// {x: 1, y: 2, a: 3, b: 4}
引用:
传播特性 JSX深入
向Brandon Morelli致敬。他在这里解释得很好,但链接可能会消失,所以我只是粘贴下面的内容:
扩展语法就是三个点:… 它允许迭代对象在需要0+参数的地方展开。 没有上下文的定义很难。让我们探索一些不同的用例来帮助理解这意味着什么。
例1 -插入数组
看看下面的代码。在这段代码中,我们没有使用spread语法:
Var mid = [3,4]; Var arr = [1,2, mid, 5,6]; console.log (arr);
上面,我们已经创建了一个名为mid的数组,然后我们创建了第二个包含我们的mid数组的数组。最后,我们登出结果。你希望arr打印什么?点击上面的运行看看会发生什么。输出如下:
[1, 2, [3, 4], 5, 6]
这是你预期的结果吗?
通过将mid数组插入到arr数组中,我们就得到了一个数组中的一个数组。如果这是我们的目标,那也没关系。但是如果您只想要一个值从1到6的数组呢?要做到这一点,我们可以使用spread语法!请记住,展开语法允许数组的元素展开。
让我们看看下面的代码。一切都是一样的-除了我们现在使用spread语法将mid数组插入到arr数组中:
Var mid = [3,4]; Var arr =[1,2,…]Mid, 5,6]; console.log (arr);
当你点击运行按钮时,结果是这样的:
[1, 2, 3, 4, 5, 6]
太棒了!
还记得刚才读到的扩展语法定义吗?这就是它发挥作用的地方。如你所见,当我们创建arr数组并在中间数组上使用展开运算符时,中间数组不仅被插入,还会展开。这种展开意味着中间数组中的每个元素都被插入到arr数组中。结果不是嵌套数组,而是一个从1到6的数字数组。
例2 -数学
JavaScript有一个内置的数学对象,允许我们进行一些有趣的数学计算。在本例中,我们将查看Math.max()。如果您不熟悉,Math.max()返回0或多个数字中最大的一个。下面是一些例子:
Math.max();
// -Infinity
Math.max(1, 2, 3);
// 3
Math.max(100, 3, 4);
// 100
如您所见,如果要找到多个数字的最大值,Math.max()需要多个参数。不幸的是,您不能简单地使用单个数组作为输入。在使用扩展语法之前,在数组上使用Math.max()最简单的方法是使用.apply()。
Var arr = [2,4,8,6,0]; 函数max(arr) { Math.max返回。应用(null, arr); } console.log (max (arr));
它很管用,只是真的很烦人。
现在看看我们如何用spread语法做同样的事情:
Var arr = [2,4,8,6,0]; var max = Math.max(…arr); console.log (max);
我们不需要创建函数并利用apply方法返回Math.max()的结果,只需要两行代码!扩展语法展开数组元素,并将数组中的每个元素分别输入Math.max()方法!
例3 -复制Array
在JavaScript中,不能通过将新变量设置为已经存在的数组来复制数组。考虑下面的代码示例:
Var arr = ['a', 'b', 'c']; Var arr2 = arr; console.log (arr2);
当你按下run,你会得到以下输出:
['a', 'b', 'c']
现在,乍一看,它看起来是可行的-看起来我们已经把arr的值复制到arr2中。但事实并非如此。你看,在JavaScript中处理对象(数组是对象的一种类型)时,我们通过引用而不是通过值赋值。这意味着arr2被分配给了与arr相同的引用。换句话说,我们对arr2所做的任何事情也会影响原始的arr数组(反之亦然)。看看下面的内容:
Var arr = ['a', 'b', 'c']; Var arr2 = arr; arr2.push (' d '); console.log (arr);
上面,我们将一个新元素d放入arr2中。然而,当我们注销arr的值时,你会看到d的值也被添加到该数组中:
['a', 'b', 'c', 'd']
不过没必要害怕!我们可以使用扩展运算符! 考虑下面的代码。几乎和上面一样。相反,我们在一对方括号中使用了展开操作符:
Var arr = ['a', 'b', 'c']; Var arr2 =[…arr]; console.log (arr2);
点击运行,你将看到预期的输出:
['a', 'b', 'c']
上面,arr中的数组值扩展为单独的元素,然后赋值给arr2。现在我们可以随心所欲地改变arr2数组,而不会对原始的arr数组产生任何影响:
Var arr = ['a', 'b', 'c']; Var arr2 =[…arr]; arr2.push (' d '); console.log (arr);
同样,这是因为arr的值被展开以填充arr2数组定义的括号。因此,我们将arr2设置为等于arr的各个值,而不是像第一个例子中那样设置为对arr的引用。
奖励示例-字符串到数组
作为有趣的最后一个示例,您可以使用spread语法将字符串转换为数组。只需在一对方括号内使用spread语法:
var str = “hello”; var chars = [...p]; 控制台.log(字符);
... (JavaScript中的三个点)被称为扩展语法或扩展操作符。这允许一个可迭代对象(如数组表达式或字符串)被展开,或一个对象表达式被展开。这不是React特有的。它是一个JavaScript操作符。
这里所有的答案都是有用的,但我想列出最常用的传播语法(传播操作符)的实际用例。
1. 组合数组(串联数组)
组合数组的方法有很多种,但展开操作符允许您将其放置在数组中的任何位置。如果你想组合两个数组,并将元素放置在数组中的任何位置,你可以这样做:
var arr1 = ['two', 'three'];
var arr2 = ['one', ...arr1, 'four', 'five'];
// arr2 = ["one", "two", "three", "four", "five"]
2. 复制数组
当我们想要一个数组的副本时,我们使用array .prototype.slice()方法。但是,你也可以用展开运算符做同样的事情。
var arr = [1,2,3];
var arr2 = [...arr];
// arr2 = [1,2,3]
3.调用没有应用的函数
在ES5中,要将两个数字的数组传递给doStuff()函数,你经常使用function .prototype.apply()方法,如下所示:
function doStuff (x, y, z) {}
var args = [0, 1, 2];
// Call the function, passing args
doStuff.apply(null, args);
但是,通过使用展开操作符,可以将数组传递给函数。
doStuff(...args);
4. 解构数组
你可以使用解构和rest操作符一起将信息提取到你想要的变量中:
let { x, y, ...z } = { x: 1, y: 2, a: 3, b: 4 };
console.log(x); // 1
console.log(y); // 2
console.log(z); // { a: 3, b: 4 }
5. 函数参数作为Rest参数
ES6还有三个点(…),它表示一个rest形参,将函数的所有剩余参数收集到一个数组中。
function f(a, b, ...args) {
console.log(args);
}
f(1, 2, 3, 4, 5); // [3, 4, 5]
6. 使用数学函数
任何将spread用作实参的函数都可以被接受任意数量实参的函数使用。
let numbers = [9, 4, 7, 1];
Math.min(...numbers); // 1
7. 两个对象合并
您可以使用展开运算符来合并两个对象。这是一种简单明了的方法。
var carType = {
model: 'Toyota',
yom: '1995'
};
var carFuel = 'Petrol';
var carData = {
...carType,
carFuel
}
console.log(carData);
// {
// model: 'Toyota',
// yom: '1995',
// carFuel = 'Petrol'
// }
8. 将字符串分离为单独的字符
您可以使用展开运算符将字符串展开为单独的字符。
let chars = ['A', ...'BC', 'D'];
console.log(chars); // ["A", "B", "C", "D"]
您可以想到更多使用扩展操作符的方法。我在这里列出的是它的流行用例。
传播算子!由于大多数人已经优雅地回答了这个问题,我想建议一个快速使用扩散操作符的方法列表:
…spread运算符对JavaScript中许多不同的常规任务都很有用,包括:
复制数组 连接或组合数组 使用数学函数 使用数组作为参数 向列表中添加项 在React中添加状态 结合对象 将NodeList转换为数组
查看文章了解更多细节。如何使用展开运算符。我建议你习惯它。有很多很酷的方法可以使用展开运算符。
... 3个点代表JS中的展开运算符。
没有展开运算符。
let a = ['one','one','two','two'];
let unq = [new Set(a)];
console.log(a);
console.log(unq);
输出:
(4) ['one', 'one', 'two', 'two']
[Set(2)]
带有展开运算符。
let a = ['one','one','two','two'];
let unq = [...new Set(a)];
console.log(a);
console.log(unq);
输出:
(4) ['one', 'one', 'two', 'two']
(2) ['one', 'two']