JavaScript中的load指的是頁面資源加載完成后所觸發(fā)的事件。當(dāng)HTML頁面中的所有資源,如CSS、JavaScript、圖片等都被加載完畢后,瀏覽器會自動觸發(fā)load事件。這個事件通常被用來用于處理異步資源加載后執(zhí)行的回調(diào)函數(shù)。
例如,在一個網(wǎng)站首頁,頁面需要大量的資源,如圖像、CSS、JavaScript和各種插件。如果未等到所有資源都加載完畢就直接給用戶展示頁面,可能會使頁面樣式錯亂或交互效果不佳。所以需要在所有資源加載完畢后再渲染頁面,從而達(dá)到更好的用戶體驗。
window.onload = function() {
// code to be executed after all resources are loaded
}
load事件還經(jīng)常出現(xiàn)在動態(tài)創(chuàng)建元素的場景中。例如,像通過JavaScript代碼創(chuàng)建一個img標(biāo)簽來動態(tài)加載一個圖片,在這個圖片加載完成后,頁面需要做一些響應(yīng),如改變二維碼的內(nèi)容或更新頁面中顯示的圖片。
const img = document.createElement('img');
img.src = 'image.jpg';
img.onload = function() {
// code to be executed after the image is loaded and ready
console.log('Image is loaded successfully');
}
document.body.appendChild(img);
除了load事件外,還有一個與之相關(guān)的事件叫做DOMContentLoaded事件。當(dāng)瀏覽器解析文檔內(nèi)容時,它會加載HTML、CSS和JavaScript,并在完成之后觸發(fā)DOMContentLoaded事件。這意味著,在所有資源都加載完成前,頁面已經(jīng)準(zhǔn)備好了,可以進(jìn)行DOM操作。DOMContentLoaded事件常常用于不依賴于資源的頁面初始化操作。
document.addEventListener('DOMContentLoaded', function() {
// code to be executed after the DOM is ready
console.log('DOM is ready');
});
總之,JavaScript中的load事件是在頁面所有資源加載完成后觸發(fā)的事件。無論是處理異步資源加載后執(zhí)行的回調(diào)函數(shù),還是在創(chuàng)建元素或初始化頁面時使用它,load事件都非常常用。