JavaScript ialah bahasa yang serba boleh dan berkuasa, tetapi ia juga boleh menjadi sumber kesesakan prestasi jika tidak dioptimumkan dengan betul. Dalam artikel ini, kami akan meneroka beberapa teknik utama untuk mengoptimumkan kod JavaScript, disertakan dengan contoh untuk menggambarkan setiap titik.
Memanipulasi Model Objek Dokumen (DOM) ialah salah satu operasi yang paling memakan masa dalam JavaScript. Untuk meminimumkan akses DOM, anda hendaklah:
Contoh:
// Inefficient DOM manipulation for (let i = 0; i < 1000; i++) { let div = document.createElement('div'); div.textContent = i; document.body.appendChild(div); } // Optimized with Document Fragment let fragment = document.createDocumentFragment(); for (let i = 0; i < 1000; i++) { let div = document.createElement('div'); div.textContent = i; fragment.appendChild(div); } document.body.appendChild(fragment);
Pengendali acara boleh menyala dengan kerap, terutamanya untuk acara seperti menatal atau mengubah saiz. Untuk mengoptimumkan, gunakan teknik nyahlantun atau pendikit untuk mengehadkan kadar pengendali ini melaksanakan.
Contoh:
// Debounce function function debounce(func, wait) { let timeout; return function(...args) { clearTimeout(timeout); timeout = setTimeout(() => func.apply(this, args), wait); }; } // Throttle function function throttle(func, limit) { let inThrottle; return function(...args) { if (!inThrottle) { func.apply(this, args); inThrottle = true; setTimeout(() => inThrottle = false, limit); } }; } // Usage window.addEventListener('resize', debounce(() => { console.log('Resized'); }, 200)); window.addEventListener('scroll', throttle(() => { console.log('Scrolled'); }, 100));
Menyekat urutan utama dengan operasi segerak boleh membawa kepada pengalaman pengguna yang buruk. Gunakan teknik tak segerak seperti async/wait, Promises, atau setTimeout untuk memastikan urutan utama responsif.
Contoh:
// Synchronous operation (blocking) function fetchData() { let response = fetch('https://api.example.com/data'); // Blocking console.log(response); } // Asynchronous operation (non-blocking) async function fetchDataAsync() { let response = await fetch('https://api.example.com/data'); // Non-blocking console.log(response); } fetchDataAsync();
Gelung boleh dioptimumkan dengan meminimumkan kerja yang dilakukan di dalamnya. Contohnya, cache panjang tatasusunan atau gunakan binaan gelung yang lebih cekap.
Contoh:
// Inefficient loop let arr = [1, 2, 3, 4, 5]; for (let i = 0; i < arr.length; i++) { console.log(arr[i]); } // Optimized loop for (let i = 0, len = arr.length; i < len; i++) { console.log(arr[i]); } // Using forEach arr.forEach(item => console.log(item));
Aliran semula dan pengecatan semula adalah operasi yang mahal dalam proses pemaparan penyemak imbas. Kurangkan ini dengan:
Contoh:
// Layout thrashing (inefficient) const element = document.getElementById('myElement'); element.style.width = '100px'; console.log(element.offsetWidth); element.style.height = '100px'; console.log(element.offsetHeight); // Optimized const element = document.getElementById('myElement'); element.style.cssText = 'width: 100px; height: 100px;'; const width = element.offsetWidth; const height = element.offsetHeight; console.log(width, height);
Memilih struktur data yang betul boleh meningkatkan prestasi dengan ketara. Contohnya, gunakan set untuk nilai unik dan peta untuk pasangan nilai kunci dengan carian kerap.
Contoh:
// Inefficient array search for unique values let arr = [1, 2, 3, 4, 5, 1, 2]; let uniqueArr = arr.filter((item, index) => arr.indexOf(item) === index); // Optimized using Set let uniqueSet = new Set(arr); let uniqueArrOptimized = [...uniqueSet];
Mengoptimumkan JavaScript adalah penting untuk meningkatkan prestasi dan responsif aplikasi web. Dengan meminimumkan akses DOM, menyahlantun dan mengecilkan pengendali acara, menggunakan pengaturcaraan tak segerak, mengoptimumkan gelung, meminimumkan pengaliran semula dan mengecat semula serta memilih struktur data yang cekap, anda boleh mencipta kod JavaScript yang lebih pantas dan cekap. Laksanakan teknik ini dalam projek anda untuk melihat peningkatan yang ketara dalam prestasi.
Atas ialah kandungan terperinci Mengoptimumkan JavaScript untuk Prestasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!