首頁 > web前端 > js教程 > 與 CSS-in-JS 分手

與 CSS-in-JS 分手

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2024-08-08 21:02:50
原創
692 人瀏覽過

JS 中的 CSS

「CSS-in-JS」是一個從樣式元件開始並在 Javascript 定義樣式的流程。

樣式組件、Emotion、Mantine 等

優點

  1. 適用範圍較小。
    1. 您可以使用 css 模組來縮小 CSS 範圍
  2. 它與
  3. 元件定義在同一位置。 (並置)
  4. 可以使用Javascript變數。

劣勢

  1. 存在運行時開銷
  2. 您必須下載CSS in JS庫檔案。
    1. 情感為 7.9KB。
    2. Mantine 是 134KB!

巨大的缺點

  1. 頻繁插入 CSS 規則會導致大量計算工作。
    1. 情緒與 CSS 的比較
    2. 使用 CSS 時效能提高了約 50%。
  2. 使用SSR時,會出現各種各樣的問題。
    1. 如果你查看 Emotion 儲存庫,你會發現有很多問題。

真實世界的表現比較

我們透過使用生產中實際使用的程式碼來比較 CSS-in-JS 和 Tailwind 來測量效能。

設定

  • CSS-in-JS 使用 Mantine(基於 Emotion)。
  • 效能測量使用 React 開發工具。
  • 效能測量目標是一個30 * 5的Table(元件名稱:SheetTable)。

螢幕

CSS-in-JS 와 헤어지기

實驗進展

    當您按下
  • 按鈕時,將呈現上面的螢幕
  • 在 React Profiler 中開啟錄製並按下按鈕來錄製螢幕渲染。
  • 測量SheetTable的渲染時間。
  • 總共執行5次並計算平均值。

CSS-in-JS (Mantine)

CSS-in-JS 와 헤어지기

順風

CSS-in-JS 와 헤어지기

結果

  • 渲染時間減少約 36%。
  • 即使只是更改一個儲存格程式碼也會帶來顯著的效能提升。 (當然,大部分都是細胞)
  • 在 60Hz 顯示器上,1 幀為 16ms,但 3 幀 ->變成了2幀

CSS-in-JS 와 헤어지기

結論

  • 使用靜態產生的 CSS 在效能方面好得多。
  • 除非需要使用 JS 變量,否則請使用 Tailwind。
  • (補充)引入SSR,方便放棄CSS-in-JS。
參考號

[1] https://dev.to/srmagura/why-were-writing-up-wiht-css-in-js-4g9b

以上是與 CSS-in-JS 分手的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:dev.to
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板