Untuk memberikan pengalaman pengguna yang segar dan unik, banyak tapak web menggunakan JavaScript untuk menambah baik reka bentuk, mengesahkan borang, menyemak penyemak imbas, permintaan Ajax, operasi kuki, dsb., untuk mencapai kesan dinamik tanpa menyegarkan. Walau bagaimanapun, sejumlah besar kandungan perlu dipaparkan dalam penyemak imbas, dan jika ia tidak dikendalikan dengan betul, prestasi tapak web akan menurun dengan ketara. Jadi kita perlu memahami cara untuk meningkatkan kecekapan pelaksanaan JavaScript.
Fungsi JavaScript
Dalam JavaScript, fungsi disusun sebelum digunakan. Walaupun kadangkala rentetan boleh digunakan dan bukannya fungsi, kod JavaScript ini akan dihuraikan semula setiap kali ia dilaksanakan, menjejaskan prestasi.
1. contoh eval
2. contoh setMasa
Menggunakan fungsi dan bukannya rentetan sebagai parameter memastikan kod dalam kaedah baharu boleh dioptimumkan oleh pengkompil JavaScript.
Skop JavaScript
Setiap skop dalam rantaian skop JavaScript mengandungi beberapa pembolehubah. Adalah penting untuk memahami rantaian skop untuk memanfaatkannya.
ujian fungsi() {
var localVar = "local"; //pembolehubah setempat
//Pembolehubah setempat
alert(localVar);
//Pembolehubah global
alert(this.localVar);
//Jika dokumen tidak ditemui dalam pembolehubah tempatan, cari pembolehubah global
var pageName = document.getElementById("pageName");
}
Jika terdapat pernyataan dengan atau cuba-tangkap dalam kod, rantai skop akan menjadi lebih rumit, seperti yang ditunjukkan di bawah:
Rentetan JavaScript
Fungsi dalam JavaScript yang sangat mempengaruhi prestasi ialah penggabungan rentetan Secara umumnya, simbol digunakan untuk menyambung rentetan. Walau bagaimanapun, penyemak imbas awal tidak mengoptimumkan kaedah sambungan ini, yang mengakibatkan penciptaan berterusan dan pemusnahan rentetan secara serius mengurangkan kecekapan pelaksanaan JavaScript.
Manipulasi DOM JavaScript
Model Objek Dokumen HTML (DOM) mentakrifkan cara standard untuk mengakses dan memanipulasi dokumen HTML. Ia mewakili dokumen HTML sebagai pepohon nod yang mengandungi elemen, atribut dan kandungan teks. Dengan menggunakan HTML DOM, JavaScript boleh mengakses semua nod dalam dokumen HTML dan memanipulasinya.
lukis semula DOM
Setiap kali objek DOM halaman diubah suai, ia melibatkan lukisan semula DOM dan penyemak imbas akan memaparkan semula halaman tersebut. Oleh itu, mengurangkan bilangan pengubahsuaian objek DOM boleh meningkatkan prestasi JavaScript dengan berkesan.
Adalah disyorkan untuk menukarnya kepada:
' i '
');Akses DOM
Setiap nod dalam dokumen HTML boleh diakses melalui DOM. Setiap kali anda memanggil getElementById(), getElementsByTagName() dan kaedah lain, nod akan dicari dan diakses semula. Oleh itu, caching nod DOM yang ditemui juga boleh meningkatkan prestasi JavaScript.
Adalah disyorkan untuk menukarnya kepada:
Perjalanan DOM
Perjalanan DOM bagi elemen kanak-kanak biasanya membaca elemen anak seterusnya dalam gelung mengikut indeks Dalam penyemak imbas awal, kaedah bacaan ini mempunyai kecekapan pelaksanaan yang sangat rendah. Kaedah nextSibling boleh digunakan untuk meningkatkan kecekapan js melintasi DOM.
Adalah disyorkan untuk menukarnya kepada:
Keluaran memori JavaScript
Dalam aplikasi web, apabila bilangan objek DOM bertambah, penggunaan memori akan menjadi lebih besar dan lebih besar. Oleh itu, rujukan kepada objek harus dikeluarkan dalam masa supaya penyemak imbas boleh menuntut semula memori.
Lepaskan memori yang diduduki oleh DOM
Tetapkan innerHTML elemen DOM kepada rentetan kosong untuk melepaskan memori yang diduduki oleh elemen anaknya.
Lepaskan objek javascript