Heim > Web-Frontend > js-Tutorial > Hauptteil

20 Tipps zur Verbesserung der Geschwindigkeit und Effizienz der JavaScript-Entwicklung

青灯夜游
Freigeben: 2021-06-28 10:00:29
nach vorne
2473 Leute haben es durchsucht

Die Verbesserung der Geschwindigkeit und Effizienz der JavaScript-Entwicklung ist ein sehr wichtiger Punkt in der täglichen Entwicklung. In diesem Artikel werden einige praktische und praktische Methoden und Tipps für tägliche Aufgaben vorgestellt, die Anzahl der Codezeilen reduziert, die Arbeitseffizienz verbessert und die Berührung erhöht Fischzeit.

20 Tipps zur Verbesserung der Geschwindigkeit und Effizienz der JavaScript-Entwicklung

Bei unseren täglichen Aufgaben müssen wir Funktionen schreiben, z. B. Sortieren, Suchen, Finden eindeutiger Werte, Übergeben von Parametern, Austauschen von Werten usw., daher möchte ich hier einige gängige Techniken und Methoden vorstellen, die ich verwende die sich im Laufe der Jahre angesammelt haben. Dadurch kann jeder seine Angelzeit verlängern. [Verwandte Empfehlungen: Javascript-Lern-Tutorial]

Diese Methoden werden Ihnen auf jeden Fall helfen:

  • Codezeilen reduzieren
  • Codierungswettbewerbe
  • Zeit zum Fischen erhöhen

1. Arrays deklarieren und initialisieren

Wir können eine bestimmte Größe verwenden, um das Array zu initialisieren, oder wir können den Array-Inhalt initialisieren, indem wir einen Wert angeben. Möglicherweise verwenden Sie eine Reihe von Arrays, dies kann jedoch auch für zweidimensionale Arrays erfolgen, wie unten gezeigt :

const array = Array(5).fill(''); 
// 输出
(5) ["", "", "", "", ""]

const matrix = Array(5).fill(0).map(() => Array(5).fill(0))
// 输出
(5) [Array(5), Array(5), Array(5), Array(5), Array(5)]
0: (5) [0, 0, 0, 0, 0]
1: (5) [0, 0, 0, 0, 0]
2: (5) [0, 0, 0, 0, 0]
3: (5) [0, 0, 0, 0, 0]
4: (5) [0, 0, 0, 0, 0]
length: 5
Nach dem Login kopieren

2. Summe, Minimum und Maximum

Wir sollten die Methode reduce verwenden, um schnell grundlegende mathematische Operationen zu finden. reduce 方法快速找到基本的数学运算。

const array  = [5,4,7,8,9,2];
Nach dem Login kopieren

求和

array.reduce((a,b) => a+b);
// 输出: 35
Nach dem Login kopieren

最大值

array.reduce((a,b) => a>b?a:b);
// 输出: 9
Nach dem Login kopieren

最小值

array.reduce((a,b) => a<b?a:b);
// 输出: 2
Nach dem Login kopieren

3、排序字符串,数字或对象等数组

我们有内置的方法sort()reverse()来排序字符串,但是如果是数字或对象数组呢

字符串数组排序

const stringArr = ["Joe", "Kapil", "Steve", "Musk"]
stringArr.sort();
// 输出
(4) ["Joe", "Kapil", "Musk", "Steve"]

stringArr.reverse();
// 输出
(4) ["Steve", "Musk", "Kapil", "Joe"]
Nach dem Login kopieren

数字数组排序

const array  = [40, 100, 1, 5, 25, 10];
array.sort((a,b) => a-b);
// 输出
(6) [1, 5, 10, 25, 40, 100]

array.sort((a,b) => b-a);
// 输出
(6) [100, 40, 25, 10, 5, 1]
Nach dem Login kopieren

对象数组排序

const objectArr = [ 
    { first_name: &#39;Lazslo&#39;, last_name: &#39;Jamf&#39;     },
    { first_name: &#39;Pig&#39;,    last_name: &#39;Bodine&#39;   },
    { first_name: &#39;Pirate&#39;, last_name: &#39;Prentice&#39; }
];
objectArr.sort((a, b) => a.last_name.localeCompare(b.last_name));
// 输出 
(3) [{…}, {…}, {…}]
0: {first_name: "Pig", last_name: "Bodine"}
1: {first_name: "Lazslo", last_name: "Jamf"}
2: {first_name: "Pirate", last_name: "Prentice"}
length: 3
Nach dem Login kopieren

4、从数组中过滤到虚值

0, undefined, null, false, "", &#39;&#39;这样的假值可以通过下面的技巧轻易地过滤掉。

const array = [3, 0, 6, 7, &#39;&#39;, false];
array.filter(Boolean);


// 输出
(3) [3, 6, 7]
Nach dem Login kopieren

5、使用逻辑运算符处理需要条件判断的情况

function doSomething(arg1){ 
    arg1 = arg1 || 10; 
// 如果arg1没有值,则取默认值 10
}

let foo = 10;  
foo === 10 && doSomething(); 
// 如果 foo 等于 10,刚执行 doSomething();
// 输出: 10

foo === 5 || doSomething();
// is the same thing as if (foo != 5) then doSomething();
// Output: 10
Nach dem Login kopieren

6、去除重复值

const array  = [5,4,7,8,9,2,7,5];
array.filter((item,idx,arr) => arr.indexOf(item) === idx);
// or
const nonUnique = [...new Set(array)];
// Output: [5, 4, 7, 8, 9, 2]
Nach dem Login kopieren

7、创建一个计数器对象或 Map

大多数情况下,可以通过创建一个对象或者Map来计数某些特殊词出现的频率。

let string = &#39;kapilalipak&#39;;

const table={}; 
for(let char of string) {
  table[char]=table[char]+1 || 1;
}
// 输出
{k: 2, a: 3, p: 2, i: 2, l: 2}
Nach dem Login kopieren

或者

const countMap = new Map();
  for (let i = 0; i < string.length; i++) {
    if (countMap.has(string[i])) {
      countMap.set(string[i], countMap.get(string[i]) + 1);
    } else {
      countMap.set(string[i], 1);
    }
  }
// 输出
Map(5) {"k" => 2, "a" => 3, "p" => 2, "i" => 2, "l" => 2}
Nach dem Login kopieren

8、三元运算符很酷

function Fever(temp) {
    return temp > 97 ? &#39;Visit Doctor!&#39;
      : temp < 97 ? &#39;Go Out and Play!!&#39;
      : temp === 97 ? &#39;Take Some Rest!&#39;: &#39;Go Out and Play!&#39;;;
}

// 输出
Fever(97): "Take Some Rest!" 
Fever(100): "Visit Doctor!"
Nach dem Login kopieren

9、循环方法的比较

  • forfor..in 默认获取索引,但你可以使用arr[index]
  • for..in也接受非数字,所以要避免使用。
  • forEach, for...of 直接得到元素。
  • forEach 也可以得到索引,但 for...of 不行。

10、合并两个对象

const user = { 
 name: &#39;Kapil Raghuwanshi&#39;, 
 gender: &#39;Male&#39; 
 };
const college = { 
 primary: &#39;Mani Primary School&#39;, 
 secondary: &#39;Lass Secondary School&#39; 
 };
const skills = { 
 programming: &#39;Extreme&#39;, 
 swimming: &#39;Average&#39;, 
 sleeping: &#39;Pro&#39; 
 };

const summary = {...user, ...college, ...skills};

// 合并多个对象
gender: "Male"
name: "Kapil Raghuwanshi"
primary: "Mani Primary School"
programming: "Extreme"
secondary: "Lass Secondary School"
sleeping: "Pro"
swimming: "Average"
Nach dem Login kopieren

11、箭头函数

箭头函数表达式是传统函数表达式的一种替代方式,但受到限制,不能在所有情况下使用。因为它们有词法作用域(父作用域),并且没有自己的thisargument,因此它们引用定义它们的环境。

const person = {
name: &#39;Kapil&#39;,
sayName() {
    return this.name;
    }
}
person.sayName();
// 输出
"Kapil"
Nach dem Login kopieren

但是这样:

const person = {
name: &#39;Kapil&#39;,
sayName : () => {
    return this.name;
    }
}
person.sayName();
// Output
"
Nach dem Login kopieren

12、可选的链

const user = {
  employee: {
    name: "Kapil"
  }
};
user.employee?.name;
// Output: "Kapil"
user.employ?.name;
// Output: undefined
user.employ.name
// 输出: VM21616:1 Uncaught TypeError: Cannot read property &#39;name&#39; of undefined
Nach dem Login kopieren

13、洗牌一个数组

利用内置的Math.random()

const list = [1, 2, 3, 4, 5, 6, 7, 8, 9];
list.sort(() => {
    return Math.random() - 0.5;
});
// 输出
(9) [2, 5, 1, 6, 9, 8, 4, 3, 7]
// 输出
(9) [4, 1, 7, 5, 3, 8, 2, 9, 6]
Nach dem Login kopieren

Summe

const foo = null ?? &#39;my school&#39;;
// 输出: "my school"

const baz = 0 ?? 42;
// 输出: 0
Nach dem Login kopieren
Maximalwert

function myFun(a,  b, ...manyMoreArgs) {
   return arguments.length;
}
myFun("one", "two", "three", "four", "five", "six");

// 输出: 6
Nach dem Login kopieren
Minimalwert
const parts = [&#39;shoulders&#39;, &#39;knees&#39;]; 
const lyrics = [&#39;head&#39;, ...parts, &#39;and&#39;, &#39;toes&#39;]; 

lyrics;
// 输出: 
(5) ["head", "shoulders", "knees", "and", "toes"]
Nach dem Login kopieren

3. Sortieren Sie Arrays aus Zeichenfolgen, Zahlen oder Objekten.

Wir haben die eingebaute Methode sort () und reverse(), um Zeichenfolgen zu sortieren, aber was ist, wenn es sich um ein Array aus Zahlen oder Objekten handelt? Objekt-Array-Sortierung

const search = (arr, low=0,high=arr.length-1) => {
    return high;
}
search([1,2,3,4,5]);

// 输出: 4
Nach dem Login kopieren
4. Filtern Sie virtuelle Werte aus dem Array heraus

wie 0, undefiniert, null , Falsche Werte wie false, "", '' können mit den folgenden Techniken leicht herausgefiltert werden.

const num = 10;

num.toString(2);
// 输出: "1010"
num.toString(16);
// 输出: "a"
num.toString(8);
// 输出: "12"
Nach dem Login kopieren

5. Verwenden Sie logische Operatoren, um Situationen zu behandeln, die eine bedingte Beurteilung erfordern.

let a = 5;
let b = 8;
[a,b] = [b,a]

[a,b]
// 输出
(2) [8, 5]
Nach dem Login kopieren
function checkPalindrome(str) {
  return str == str.split(&#39;&#39;).reverse().join(&#39;&#39;);
}
checkPalindrome(&#39;naman&#39;);
// 输出: true
Nach dem Login kopieren

Most In In diesem Fall können Sie ein Objekt oder eine Karte erstellen, um die Häufigkeit bestimmter Sonderwörter zu zählen.

const obj = { a: 1, b: 2, c: 3 };

Object.entries(obj);
// Output
(3) [Array(2), Array(2), Array(2)]
0: (2) ["a", 1]
1: (2) ["b", 2]
2: (2) ["c", 3]
length: 3

Object.keys(obj);
(3) ["a", "b", "c"]

Object.values(obj);
(3) [1, 2, 3]
Nach dem Login kopieren
oder rrreee

8. Der ternäre Operator ist cool

🎜🎜rrreee🎜🎜🎜9. Vergleich der Schleifenmethoden🎜🎜🎜🎜🎜for und for.. in ruft standardmäßig den Index ab, Sie können jedoch auch arr[index] verwenden. 🎜🎜for..in akzeptiert auch Nicht-Zahlen, also vermeiden Sie die Verwendung. 🎜🎜forEach, for...of holen sich das Element direkt. 🎜🎜forEach kann auch den Index abrufen, for...of jedoch nicht. 🎜🎜🎜🎜🎜10. Zwei Objekte zusammenführen🎜🎜🎜rrreee🎜🎜🎜11. Pfeilfunktionsausdrücke sind eine Alternative zu herkömmlichen Funktionsausdrücken, sind jedoch eingeschränkt und können nicht in allen Situationen verwendet werden. Da sie einen lexikalischen Gültigkeitsbereich (übergeordneter Gültigkeitsbereich) haben und kein eigenes this und argument haben, verweisen sie auf die Umgebung, in der sie definiert sind. 🎜rrreee🎜Aber das:🎜rrreee🎜🎜🎜12. Optionale Kette🎜🎜🎜rrreee🎜🎜🎜13. Mischen Sie ein Array🎜🎜🎜🎜Verwenden Sie die integrierte Math.random()-Methode. 🎜rrreee🎜🎜🎜14. Doppelte Fragezeichensyntax🎜🎜🎜rrreee🎜🎜🎜15. Verbleibende und Erweiterungssyntax🎜🎜🎜rrreee🎜🎜🎜16 🎜🎜🎜rrreee 🎜🎜🎜17 Für binär oder hexadezimal🎜🎜🎜rrreee🎜🎜🎜18. Verwenden Sie die Destrukturierung, um zwei Zahlen auszutauschen🎜🎜🎜rrreee🎜🎜🎜19. Einzeilige Palindrom-Zahlenprüfung🎜🎜🎜rrreee🎜🎜🎜20. Ändern Sie die Objekteigenschaft „In Attribut konvertieren“. array🎜🎜🎜rrreee🎜Weitere Programmierkenntnisse finden Sie unter: 🎜Einführung in die Programmierung🎜! ! 🎜

Das obige ist der detaillierte Inhalt von20 Tipps zur Verbesserung der Geschwindigkeit und Effizienz der JavaScript-Entwicklung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:segmentfault.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!