91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript的DOM運行速度如何提升

發布時間:2022-05-23 16:12:53 來源:億速云 閱讀:93 作者:iii 欄目:大數據

這篇“JavaScript的DOM運行速度如何提升”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“JavaScript的DOM運行速度如何提升”文章吧。

我們都知道,DOM操作的效率是很低的,而且不是一般的慢,而且這也是引發性能問題的常見問題之一。為什么會慢呢?因為對DOM的修改為影響網頁的用戶界面,重繪頁面是一項昂貴的操作。太多的DOM操作會導致一系列的重繪操作,為了確保執行結果的準確性,所有的修改操作是按順序同步執行的。我們稱這個過程叫做回流(reflow),同時這也是最昂貴的瀏覽器操作之一。回流操作主要會發生在幾種情況下:

◆當對DOM節點執行新增或者刪除操作時。

◆動態設置一個樣式時(比如element.style.width="10px")。

◆當獲取一個必須經過計算的尺寸值時,比如訪問offsetWidth、clientHeight或者其他需要經過計算的CSS值(在兼容DOM的瀏覽器中,可以通過getComputedStyle函數獲取;在IE中,可以通過currentStyle屬性獲取)。
解決問題的關鍵,就是限制通過DOM操作所引發回流的次數。大部分瀏覽器都不會在JavaScript的執行過程中更新DOM。相應的,這些瀏覽器將對對DOM的操作放進一個隊列,并在JavaScript腳本執行完畢以后按順序一次執行完畢。也就是說,在JavaScript執行的過程中,用戶不能和瀏覽器進行互動,直到一個回流操作被執行。( 失控腳本對話框 會觸發回流操作,因為他執行了一個中止JavaScript執行的操作,此時會對用戶界面進行更新)

如果要減少由于DOM修改帶來的回流操作,有兩個基本的方法。***個就是在對當前DOM進行操作之前,盡可能多的做一些準備工作。一個經典的例子就是向document對象中添加很多DOM節點:

for (var i=0; i < items.length; i++){      var item = document.createElement("li");      item.appendChild(document.createTextNode("Option " + i);      list.appendChild(item);  }

這段代碼的效率是很低的,因為他在每次循環中都會修改當前DOM結構。為了提高性能,我們需要將這個次數降到***,對于這個案例來說,***的辦法是建立一個文檔碎片(document fragment),作為那些已創建元素元素的臨時容器,***一次將容器的內容直接添加到父節點中:

var fragment = document.createDocumentFragment();  for (var i=0; i < items.length; i++){      var item = document.createElement("li");      item.appendChild(document.createTextNode("Option " + i);      fragment.appendChild(item);  }  list.appendChild(fragment);

經過調整的代碼,只會修改一次當前DOM的結構,就在***一行,而在這之前,我們用文檔碎片來保存那些中間結果。因為文檔碎片沒有任何可見內容,所以這類修改不會觸發回流操作。實際上,文檔碎片也不能被添加到DOM中,我們需要將它作為參數傳給appendChild函數,而實際上添加的不是文檔碎片本身,而是它下面的所有子元素。

以上就是關于“JavaScript的DOM運行速度如何提升”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

时尚| 邹城市| 若尔盖县| 中宁县| 枣强县| 盐池县| 开封市| 青阳县| 涞水县| 蓬溪县| 黄骅市| 樟树市| 嵩明县| 吉木萨尔县| 平顺县| 丰都县| 日喀则市| 务川| 贡山| 兰坪| 汉源县| 子洲县| 镇安县| 陆河县| 潮州市| 锡林浩特市| 福安市| 汾阳市| 神木县| 新丰县| 保定市| 杂多县| 福鼎市| 蕉岭县| 手游| 阿瓦提县| 永春县| 禄丰县| 靖江市| 富民县| 甘泉县|