js防止DIV版面滾動時閃爍的解決方法_javascript技巧
本文實例講述了js防止DIV版面滾動時閃爍的方法,分享給大家供大家參考。具體方法如下:
最近接觸頁面效能的東西,有很多細微又原始的內容,像是瀏覽器渲染。資料非常多,所以選一些做節譯,備忘。
JavaScript多次寫、讀DOM就會發生「佈局顛簸」,引起文件重排(reflow – the process of constructing a render tree
// 讀
var h1 = element1.clientHeight;
// 寫入 (版面作廢)
element1.style.height = (h1 * 2) 'px';
// 讀 (觸發版面)
var h2 = element2.clientHeight;
// 寫入 (版面作廢)
element2.style.height = (h2 * 2) 'px';
// 讀 (觸發版面)
var h3 = element3.clientHeight;
// 寫入 (版面作廢)
element3.style.height = (h3 * 2) 'px';
DOM被寫時,版面就作廢了,需要在某個時間點重排。但瀏覽器很懶,它想等到目前操作(或說幀)結束前再來重排。
不過,如果我們在當前操作(或說幀)結束前從DOM中讀取幾何數值,那麼我們就強制瀏覽器提前重排佈局,這就是所謂的「強制同步佈局」(forced synchonous layout),它會要了性能的命。
在現代的桌面瀏覽器上,佈局顛簸的副作用可能並不明顯;但放到低端行動裝置上,問題就很嚴重了。
快速解決方法
在一個理想世界裡,我們只要簡單地重新排列程式碼執行順序,就可以批次讀DOM、批次寫DOM。這意味著,文件只需一次重排。
var h1 = element1.clientHeight;
var h2 = element2.clientHeight;
var h3 = element3.clientHeight;
// 寫入 (版面作廢)
element1.style.height = (h1 * 2) 'px';
element2.style.height = (h2 * 2) 'px';
element3.style.height = (h3 * 2) 'px';
// 文檔在幀末重排
現實世界又如何?
現實中可就沒那麼簡單。大型程式中,程式碼散播各處,個個都存在這類危險的DOM。我們沒辦法輕鬆(顯然也不應該)把我們漂亮的、解藕的程式碼揉合一塊,就只是為了控制住執行順序。那麼為了優化效能,我們怎麼把讀和寫做批量處理?
來認識requestAnimationFrame
window.requestAnimationFrame安排一個函數在下一幀執行,類似setTimout(fn, 0)。這非常有用,因為我們可以用它來排定所有的DOM寫操作在下一幀一同執行,DOM讀取操作就按現在的順序同步執行。
var h1 = element1.clientHeight;
// 寫
requestAnimationFrame(function() {
element1.style.height = (h1 * 2) 'px';
});
// 讀
var h2 = element2.clientHeight;
// 寫
requestAnimationFrame(function() {
element2.style.height = (h2 * 2) 'px';
});
……
希望本文所述對大家基於javascript的web程式設計有所幫助。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

使用AJAX從服務器獲取數據時Bootstrap Table出現亂碼的解決方法:1. 設置服務器端代碼的正確字符編碼(如UTF-8)。 2. 在AJAX請求中設置請求頭,指定接受的字符編碼(Accept-Charset)。 3. 使用Bootstrap Table的"unescape"轉換器將已轉義的HTML實體解碼為原始字符。

Bootstrap 列表的默認樣式可以通過 CSS 覆蓋來移除。使用更具體的 CSS 規則和選擇器,遵循 "就近原則" 和 "權重原則",覆蓋 Bootstrap 默認的樣式。為避免樣式衝突,可使用更具針對性的選擇器。如果遇到覆蓋不成功的情況,可調整自定義 CSS 的權重。同時注意性能優化,避免過度使用 !important,撰寫簡潔高效的 CSS 代碼。

MySQL安裝報錯的解決方法是:1.仔細檢查系統環境,確保滿足MySQL的依賴庫要求,不同操作系統和版本需求不同;2.認真閱讀報錯信息,根據提示(例如缺少庫文件或權限不足)採取對應措施,例如安裝依賴或使用sudo命令;3.必要時,可嘗試源碼安裝並仔細檢查編譯日誌,但這需要一定的Linux知識和經驗。最終解決問題的關鍵在於仔細檢查系統環境和報錯信息,並參考官方文檔。

可以通過以下步驟解決 Navicat 無法連接數據庫的問題:檢查服務器連接,確保服務器運行、地址和端口正確,防火牆允許連接。驗證登錄信息,確認用戶名、密碼和權限正確。檢查網絡連接,排除網絡問題,例如路由器或防火牆故障。禁用 SSL 連接,某些服務器可能不支持。檢查數據庫版本,確保 Navicat 版本與目標數據庫兼容。調整連接超時,對於遠程或較慢的連接,增加連接超時時間。其他解決方法,如果上述步驟無效,可以嘗試重新啟動軟件,使用不同的連接驅動程序,或諮詢數據庫管理員或 Navicat 官方支持。

無法以 root 身份登錄 MySQL 的原因主要在於權限問題、配置文件錯誤、密碼不符、socket 文件問題或防火牆攔截。解決方法包括:檢查配置文件中 bind-address 參數是否正確配置。查看 root 用戶權限是否被修改或刪除,並進行重置。驗證密碼是否準確無誤,包括大小寫和特殊字符。檢查 socket 文件權限設置和路徑。檢查防火牆是否阻止了 MySQL 服務器的連接。

Vue 中 export default 揭秘:默認導出,一次性導入整個模塊,無需指定名稱。編譯時將組件轉換為模塊,通過構建工具打包生成可用的模塊。可與命名導出結合,同時導出其他內容,如常量或函數。常見問題包括循環依賴、路徑錯誤和構建錯誤,需要仔細檢查代碼和導入語句。最佳實踐包括代碼分割、可讀性和組件復用。

無法連接 MySQL 可能是由於以下原因:MySQL 服務未啟動、防火牆攔截連接、端口號錯誤、用戶名或密碼錯誤、my.cnf 中的監聽地址配置不當等。排查步驟包括:1. 檢查 MySQL 服務是否正在運行;2. 調整防火牆設置以允許 MySQL 監聽 3306 端口;3. 確認端口號與實際端口號一致;4. 檢查用戶名和密碼是否正確;5. 確保 my.cnf 中的 bind-address 設置正確。

MySQL安裝失敗的原因主要有:1.權限問題,需以管理員身份運行或使用sudo命令;2.依賴項缺失,需安裝相關開發包;3.端口衝突,需關閉佔用3306端口的程序或修改配置文件;4.安裝包損壞,需重新下載並驗證完整性;5.環境變量配置錯誤,需根據操作系統正確配置環境變量。解決這些問題,仔細檢查每個步驟,就能順利安裝MySQL。
