[轉(zhuǎn)帖]關(guān)于 CSS 的那些事兒,我從未被告知
當(dāng)前位置:點(diǎn)晴教程→知識管理交流
→『 技術(shù)文檔交流 』
:關(guān)于 CSS 的那些事兒,我從未被告知 關(guān)于 CSS 的那些事兒,我從未被告知CSS 性能CSS 性能是一個(gè)非常重要的話題,因?yàn)樗苯佑绊懢W(wǎng)站的效率。由于現(xiàn)代應(yīng)用程序包含大量的 CSS 代碼,即使是微小的錯(cuò)誤也可能導(dǎo)致顯著的性能下降。 子選擇器首先,下面賂你展示一些令我驚訝的東西。只需看看下面的例子,試著找出可能的問題。 正如你所看到的,這個(gè)例子一點(diǎn)都不復(fù)雜。這段 CSS 代碼移除了標(biāo)題中所有段落內(nèi)鏈接的文本裝飾。這不是普通的 CSS 嗎? 但你知道使用這樣的選擇器會(huì)導(dǎo)致瀏覽器執(zhí)行大量額外工作嗎?這個(gè)問題適用于我們代碼中所有類似的子選擇器。 這是因?yàn)闉g覽器在解析 CSS 時(shí),從右向左讀取選擇器。有了這個(gè)新知識,我們將這個(gè)過程分解成幾個(gè)步驟:
通過使用更具體的選擇器,我們可以幫助瀏覽器避免所有這些額外的工作。我們可以將 昂貴的 CSS 屬性所謂昂貴的 CSS 屬性,是指這些屬性在我們的應(yīng)用程序中可能會(huì)耗費(fèi)大量性能。但這并不意味著你完全不能使用它們。你只需要理解,如果元素使用了這些屬性并且經(jīng)常渲染——它肯定會(huì)影響性能。 需要注意的一件棘手事情是,改變某些 CSS 屬性需要更新整個(gè)布局。幾何屬性如寬度、高度、頂部等可能導(dǎo)致整個(gè)樹的重新繪制。 還有一些屬性很難渲染。雖然這些屬性的清單很短,但你可以在這里了解更多關(guān)于它們的信息。
重繪和重排重繪(Repaint)和重排(Reflow)是在瀏覽器中渲染網(wǎng)頁過程中兩個(gè)重要的概念。當(dāng)頁面加載或更新時(shí),瀏覽器會(huì)通過一系列步驟將內(nèi)容顯示在屏幕上,而重繪和重排在這個(gè)過程中起著重要作用。 為了更好地理解這個(gè)過程,我們可以將其分解為幾個(gè)精確的步驟:
當(dāng)頁面首次加載時(shí),如果不是空的,至少會(huì)執(zhí)行一次重排和重繪。但它們也會(huì)在以下情況下繼續(xù)發(fā)生:
關(guān)于重排重排是計(jì)算網(wǎng)頁上元素布局的過程。它根據(jù)元素的內(nèi)容和樣式來確定每個(gè)元素的大小和位置。 在現(xiàn)代應(yīng)用程序中,特別是頁面上有成千上萬個(gè)元素和頻繁的布局更新時(shí),它很快會(huì)變成一個(gè)資源消耗大的操作。即使是對文檔中單個(gè)元素的重排,也可能需要重排其父元素和隨后的任何其他元素。 由于它是一個(gè)用戶阻塞操作,了解如何改進(jìn)重排以及各種文檔屬性對其持續(xù)時(shí)間的影響是非常有用的。典型的引發(fā)重排過程的情況通常有:
關(guān)于重繪重繪是將像素繪制到屏幕上的簡單過程。在重排期間確定布局后,瀏覽器將每個(gè)元素繪制到屏幕上。 重繪通常比重排消耗的資源少,但它仍然會(huì)影響網(wǎng)頁的性能。 最典型的情況是當(dāng)元素樣式的變化不影響其在屏幕上的大小或位置時(shí)。例如,當(dāng)背景顏色改變時(shí),瀏覽器只需用新樣式重新繪制(或重繪)節(jié)點(diǎn)。 以下是一些會(huì)觸發(fā)重繪的操作的例子:
CSS 可以替代 JS 的地方JavaScript 和 CSS 是非常棒的技術(shù),尤其是在一起使用時(shí)。每種技術(shù)都有其獨(dú)特的優(yōu)勢,結(jié)合使用時(shí)可以創(chuàng)造出令人難以置信的效果。 然而,我可以自信地說,UI 控制中使用 CSS 越多,Web 應(yīng)用程序就越容錯(cuò)和可靠。 觀點(diǎn)很簡單:
現(xiàn)在讓我們考慮一些你可以輕松用 CSS 替代 JS 的情況。 平滑滾動(dòng)以前,要實(shí)現(xiàn)平滑滾動(dòng),需要使用幾行 JavaScript 代碼。但現(xiàn)在,這個(gè)任務(wù)可以完全通過 CSS 的力量來解決。 現(xiàn)在你可以通過使用 CSS 屬性 文本處理CSS 提供了兩個(gè)很棒的屬性: text-overflow 屬性這個(gè)屬性控制文本在不適合一行的情況下如何顯示。這個(gè)屬性的一個(gè)完美例子是在卡片標(biāo)題中使用 請記住, line-clamp 屬性 line-clamp 屬性在需要處理多行文本時(shí)非常有用。上面示例中的卡片描述展示了它的效果。 這個(gè)屬性是 CSS Overflow Module Level 3 標(biāo)準(zhǔn)的一部分,雖然目前還處于草案階段,但已經(jīng)有大約 95% 的瀏覽器支持這個(gè)屬性,但需要加上 在使用它之前,重要的是要提到它不允許控制顯示字符的數(shù)量。但它仍然非常有用。 要使用 line-clamp 屬性,我們需要將其與 總結(jié)現(xiàn)代前端開發(fā)的世界正在迅速變化,我們不斷得到新的機(jī)會(huì)來幫助我們更快、更好地完成工作。嘗試使用 CSS 是非常有趣且有幫助的。如果在不使用 JS 的情況下可以實(shí)現(xiàn)相同的結(jié)果,請考慮使用 CSS。 該文章在 2024/6/15 17:28:53 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |