Heim >Web-Frontend >js-Tutorial >8 Tipps und Tricks zum Schreiben von exzellentem JS-Code (Teilen)
Die folgende Kolumne „JS-Tutorial“ stellt Ihnen 8 Tipps und Tricks zum Schreiben von Javascript-Code vor. Es hat einen gewissen Referenzwert. Freunde in Not können sich darauf beziehen. Ich hoffe, es wird für alle hilfreich sein.
Empfohlenes Tutorial: „
JavaScript-Video-Tutorial1. Generieren Sie Zahlen innerhalb eines bestimmten Bereichslet start = 1900, end = 2000; [...new Array(end + 1).keys()].slice(start); // [ 1900, 1901, ..., 2000] // 也可以这样,但是大范围结果不稳定 Array.from({ length: end - start + 1 }, (_, i) => start + i);2. Verwenden Sie die Werte im Wertearray als Parameter der Funktion
...
) extrahieren: [arg1, arg2] => >.
const parts = { first: [0, 2], second: [1, 3], }; ["Hello", "World", "JS", "Tricks"].slice(...parts.second); // ["World", "JS", "Tricks"]
Dieser Trick funktioniert in jeder Funktion, bitte fahren Sie mit Punkt 3 fort. ...
)就可以把值从数组中提取出来: [arg1,arg2] => (arg1,arg2)
。
// 查到元素中的 y 位置最大的那一个值 const elementsHeight = [...document.body.children].map( el => el.getBoundingClientRect().y ); Math.max(...elementsHeight); // 输出最大的那个值 const numbers = [100, 100, -1000, 2000, -3000, 40000]; Math.min(...numbers); // -3000
这个技巧在任何函数中都适用,请继续看第 3 条。
当需要在数组中找到数字的最大或最小值时,可以像下面这样做:
const arrays = [[10], 50, [100, [2000, 3000, [40000]]]]; arrays.flat(Infinity); // [ 10, 50, 100, 2000, 3000, 40000 ]
Array 有一个名为 Array.flat
的方法,它需要一个表示深度的参数来展平嵌套数组(默认值为 1)。但是如果你不知道深度怎么办,这时候只需要将 Infinity
作为参数即可。另外还有一个很好用的 flatMap 方法。
const found = [{ name: "Alex" }].find(i => i.name === 'Jim'); console.log(found.name); // TypeError: Cannot read property 'name' of undefined
如果在代码中存在不可预测的行为,后果是难以预料的,所以需要对其进行处理。
例如当你想要获取的属性为 undefined
或 null
时,会得到 TypeError
错误。
如果你的项目代码不支持可选链( optional chaining)的话,可以这样做:
const found = [{ name: "Alex" }].find(i => i.name === 'Jim') || {}; console.log(found.name); // undefined
可以这样避免
const makeList = (raw) => raw .join() .trim() .split("\n") .map((s, i) => `${i + 1}. ${s}`) .join("\n"); makeList` Hello, World Hello, World `; // 1. Hello // 2. World
不过这要视情况而定,对于小规模的代码进行处理完全没什么问题。不需要太多代码就可以处理它。
在 ES6 中可以把 模板字面量(Template literal) 当作是不带括号的函数的参数。这在进行格式化或转换文本的时非常好用。
let a = "hello"; let b = "world"; // 错误 ❌ a = b b = a // { a: 'world', b: 'world' } // 正确 ✅ [a, b] = [b, a]; // { a: 'world', b: 'hello' }
通过解构赋值语法,可以轻松地交换变量。
const password = "hackme"; password.substr(-3).padStart(password.length, "*"); // ***kme
某些时候我们需要遮蔽字符串的一部分,当然不只是对密码做这种操作。下面代码中通过 substr(-3)
得到字符串的一部分,即从字符串末尾开始往前 3 个字符,然后再用你喜欢的字符填充剩余的位置(比如说用 *
rrreee 4. Verschachtelte Arrays glättenArray verfügt über eine Methode namens
rrreeeArray.flat
, die einen Parameter erfordert, der die Tiefe zum Reduzieren verschachtelter Arrays darstellt (Standardwert ist 1). Aber was ist, wenn Sie die Tiefe nicht kennen? Zu diesem Zeitpunkt müssen Sie nurInfinity
als Parameter verwenden. Es gibt auch eine nützliche flatMap-Methode.
5. Verhindern Sie Code-Abstürze
Wenn der Code unvorhersehbares Verhalten aufweist, sind die Folgen unvorhersehbar, daher muss damit umgegangen werden. 🎜🎜Wenn die Eigenschaft, die Sie erhalten möchten, beispielsweiseundefiniert
oder null
ist, erhalten Sie einen TypeError
-Fehler. 🎜🎜Wenn Ihr Projektcode keine optionale Verkettung unterstützt, können Sie Folgendes tun: 🎜rrreee🎜Es kann auf diese Weise vermieden werden🎜rrreee🎜Aber es hängt von der Situation ab. Für Code in kleinem Maßstab gibt es überhaupt kein Problem. Es ist nicht viel Code erforderlich, um damit umzugehen. 🎜🎜🎜6. Eine gute Möglichkeit, Parameter zu übergeben🎜🎜🎜In ES6 können Sie 🎜Vorlagenliterale🎜 als Parameter von Funktionen ohne Klammern behandeln. Dies ist beim Formatieren oder Konvertieren von Text nützlich. 🎜rrreee🎜🎜7. Tauschen Sie die Werte von Variablen wie von Zauberhand aus🎜🎜🎜 Durch die Destrukturierung der Zuweisungssyntax können Sie Variablen einfach austauschen. 🎜rrreee🎜🎜8. Zeichenfolgen maskieren🎜🎜🎜Manchmal müssen wir einen Teil der Zeichenfolge maskieren, natürlich nicht nur bei Passwörtern. Im folgenden Code wird substr(-3)
verwendet, um einen Teil der Zeichenfolge abzurufen, d. h. 3 Zeichen weiter vom Ende der Zeichenfolge entfernt, und dann die verbleibenden Positionen mit Ihren Lieblingszeichen zu füllen (Verwenden Sie beispielsweise * Code>) . 🎜🎜🎜Originaladresse: https://dev.to/gigantz/9-javascript-tips-tricks-to-code-like-a-wizard-559i🎜🎜Autor: Orkhan Jafarov🎜🎜Übersetzungsadresse: https:// segmentfault.com/a/1190000030697379🎜🎜🎜Weitere Programmierkenntnisse finden Sie unter: 🎜Programmierkurse🎜! ! 🎜Das obige ist der detaillierte Inhalt von8 Tipps und Tricks zum Schreiben von exzellentem JS-Code (Teilen). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!