In diesem Artikel erfahren Sie 10 Möglichkeiten zur Verwendung des Javascript-Spread-Expansionsoperators. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.
Verwandte Empfehlungen: „Javascript-Video-Tutorial“
Wir können den Spread-Operator verwenden, um ein Array zu kopieren, aber bitte beachten Sie, dass es sich hierbei um eine „flache Kopie“ handelt. const arr1 = [1,2,3];
const arr2 = [...arr1];
console.log(arr2);
// [ 1, 2, 3 ]
Arrays kombinieren
concat
verwenden, aber jetzt können wir den Spread-Operator verwenden: const arr1 = [1,2,3]; const arr2 = [4,5,6]; const arr3 = [...arr1, ...arr2]; console.log(arr3); // [ 1, 2, 3, 4, 5, 6 ]
Wir können auch verschiedene Vereinbarungen durchgehen, um anzugeben, welche zuerst kommen soll. concat
方法,但现在可以使用展开操作符:
const arr3 = [...arr2, ...arr1]; console.log(arr3); [4, 5, 6, 1, 2, 3];
我们还可以通过不同的排列方式来说明哪个应该先出现。
const output = [...arr1, ...arr2, ...arr3, ...arr4];
此外,展开运算符号还适用多个数组的合并:
let arr1 = ['this', 'is', 'an']; arr1 = [...arr1, 'array']; console.log(arr1); // [ 'this', 'is', 'an', 'array' ]
const user = { firstname: 'Chris', lastname: 'Bongers' };
假设你有一个user
的对象,但它缺少一个age
属性。
const output = {...user, age: 31};
要向这个user
对象添加age
,我们可以再次利用展开操作符。
const arr1 = [1, -1, 0, 5, 3];
假设我们有一个数字数组,我们想要获得这些数字中的最大值、最小值或者总和。
const arr1 = [1, -1, 0, 5, 3]; const min = Math.min(...arr1); console.log(min); // -1
为了获得最小值,我们可以使用展开操作符和 Math.min
方法。
const arr1 = [1, -1, 0, 5, 3]; const max = Math.max(...arr1); console.log(max); // 5
同样,要获得最大值,可以这么做:
const arr1 = [1, -1, 0, 5, 3]; const max = Math.max(arr1); console.log(max); // NaN
如大家所见,最大值5
,如果我们删除5
,它将返回3
。
你可能会好奇,如果我们不使用展开操作符会发生什么?
const myFunc(x1, x2, x3) => { console.log(x1); console.log(x2); console.log(x3); }
这会返回NaN,因为JavaScript不知道数组的最大值是什么。
假设我们有一个函数,它有三个参数。
myFunc(1, 2, 3);
我们可以按以下方式调用这个函数:
const arr1 = [1, 2, 3];
但是,如果我们要传递一个数组会发生什么。
myFunc(...arr1); // 1 // 2 // 3
我们可以使用展开操作符将这个数组扩展到我们的函数中。
const myFunc = (x1, x2, x3) => { console.log(x1); console.log(x2); console.log(x3); }; const arr1 = [1, 2, 3]; myFunc(...arr1); // 1 // 2 // 3
这里,我们将数组分为三个单独的参数,然后传递给函数。
const myFunc = (...args) => { console.log(args); };
假设我们有一个函数,它接受无限个参数,如下所示:
myFunc(1, 'a', new Date());
如果我们现在调用这个带有多个参数的函数,会看到下面的情况:
[ 1, 'a', Date { __proto__: Date {} } ]
返回:
const el = [...document.querySelectorAll('p')]; console.log(el); // (3) [p, p, p]
然后,我们就可以动态地循环遍历参数。
假设我们使用了展开运算符来获取页面上的所有p
:
const el = [...document.querySelectorAll('p')]; el.forEach(item => { console.log(item); }); // <p></p> // <p></p> // <p></p>
在这里可以看到我们从dom中获得了3个p
。
现在,我们可以轻松地遍历这些元素,因为它们是数组了。
const user = { firstname: 'Chris', lastname: 'Bongers', age: 31 };
假设我们有一个对象user
:
const {firstname, ...rest} = user; console.log(firstname); console.log(rest); // 'Chris' // { lastname: 'Bongers', age: 31 }
现在,我们可以使用展开运算符将其分解为单个变量。
const str = 'Hello';
这里,我们解构了user
对象,并将firstname
解构为firstname
变量,将对象的其余部分解构为rest
const str = 'Hello'; const arr = [...str]; console.log(arr); // [ 'H', 'e', 'l', 'l', 'o' ]
rrreee
Attribute zu einem Objekt hinzufügenAngenommen, Sie haben ein Objekt vonuser
, aber es fehlt ein age
-Attribut. rrreee
Umage
zu diesem user
-Objekt hinzuzufügen, können wir erneut den Spread-Operator verwenden. rrreeeUm den Maximalwert zu erhalten, können Sie auch Folgendes tun:Verwendung der Math()-Funktion
Angenommen, wir haben ein Array von Zahlen und möchten das Maximum, Minimum oder die Summe dieser Zahlen ermitteln.
rrreeeUm den Mindestwert zu erhalten, können wir den Spread-Operator und die Methode
rrreeeMath.min
verwenden.
rrreeeWie Sie sehen können, ist der Maximalwert 5
, und wenn wir 5
entfernen, es wird 3
zurückgegeben.
p
s auf der Seite abzurufen: 🎜rrreee🎜Hier können Sie sehen, dass wir 3 s vom dom p. 🎜🎜Jetzt können wir diese Elemente problemlos durchlaufen, da es sich um Arrays handelt. 🎜rrreee🎜Destrukturieren eines Objekts🎜🎜Angenommen, wir haben ein Objekt <code>Benutzer
:🎜rrreee🎜Jetzt können wir den Spread-Operator verwenden, um es in einzelne Variablen zu zerlegen. 🎜rrreee🎜Hier destrukturieren wir das Objekt user
und destrukturieren firstname
in die Variable firstname
und den Rest des Objekts in restVariable. 🎜🎜Strings erweitern🎜🎜Der letzte Anwendungsfall für den Spread-Operator besteht darin, einen String in einzelne Wörter aufzuteilen. 🎜🎜Angenommen, wir haben die folgende Zeichenfolge: 🎜rrreee🎜 Wenn wir dann den Spread-Operator für diese Zeichenfolge verwenden, erhalten wir eine Reihe von Buchstaben. 🎜rrreee🎜🎜Originaladresse: https://dev.to/dailydevtips1/10-ways-to-use-the-spread-operator-in-javascript-1imb🎜🎜Autor: Chris Bongers🎜🎜Übersetzungsadresse: https:/ /segmentfault.com/a/1190000038998504🎜🎜🎜Weitere Kenntnisse zum Thema Programmierung finden Sie unter: 🎜Programmierunterricht🎜! ! 🎜
Das obige ist der detaillierte Inhalt vonTeilen Sie 10 Möglichkeiten zur Verwendung des JavaScript-Spread-Operators mit. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!