成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

CSS在DevTools 中架構演變?

開發 前端
本文主要解釋 CSS 在歷史上如何在 DevTools 中工作,以及如何在 DevTools 中現代化我們的 CSS,以準備(最終)遷移到用于在 JavaScript 文件中加載 CSS 的 Web 標準解決方案。

[[425667]]

你好,我是小弋。

這片文章描述了DevTools 架構在CSS層面所做的更改。

本文主要解釋 CSS 在歷史上如何在 DevTools 中工作,以及如何在 DevTools 中現代化我們的 CSS,以準備(最終)遷移到用于在 JavaScript 文件中加載 CSS 的 Web 標準解決方案。

DevTools 中 CSS 的先前狀態

DevTools 以兩種不同的方式實現 CSS:

  • 一種用于DevTools遺留部分中使用的 CSS 文件
  • 另一種用于 DevTools 中使用的現代 Web 組件。

對于第一種遺留部分的來說,我們翻開Chromium源碼,可以大致猜想它的實現:

Chromium源碼

DevTools 中的 CSS 實現是多年前定義的,現在已經過時了。DevTools 一直堅持使用該module.json模式,

那么我們來看下這個文件具體形式是如何的:

module.json

這些CSS文件會被放在同一個目錄下,為了將添加到 DevTools,您需要registerRequiredCSS使用要加載的文件的確切路徑進行調用。

那么它的調用如下:

  1. constructor() { 
  2.   … 
  3.   this.registerRequiredCSS('ui/legacy/components/quick_open/filteredListWidget.css'); 
  4.   … 

通過檢索CSS文件的內容后,通過appendStyle函數將內容插入到 <style>標簽中,

  1. const content = Root.Runtime.cachedResources.get(cssFile) || ''
  2.  
  3. if (!content) { 
  4.   console.error(cssFile + ' not preloaded. Check module.json'); 
  5.   
  6. const styleElement = document.createElement('style'); 
  7. styleElement.textContent = content; 
  8. node.appendChild(styleElement); 

但是,假設我們引入現代 Web 組件(使用自定義元素)時,我們最初決定在組件文件中通過內聯style>使用CSS。這帶來了自己的挑戰:

  • 缺少語法高亮支持:為內聯CSS提供語法高亮的插件往往不如為寫在.css文件中的CSS提供的語法高亮和自動完成功能好。
  • 建立性能開銷:內聯CSS也意味著需要進行兩次檢查:一次針對CSS文件,一次針對內聯CSS。如果所有的CSS都寫在獨立的CSS文件中,我們就可以消除這種性能開銷。
  • 減化體積的挑戰。內聯 CSS 不容易縮小,因此沒有任何 CSS 被縮小。DevTools 發布版本的文件大小也因同一 Web 組件的多個實例引入的重復 CSS 而增加。

基于以上的問題,那有哪些可以解決的方案呢?

研究潛在的解決方案

問題可以分為兩個不同的部分:

  • 弄清楚構建系統如何處理 CSS 文件。
  • 弄清楚 DevTools 如何導入和使用 CSS 文件。

接下來我們看下,他們是如何為每個部分研究了不同的潛在解決方案,下面概述了這些解決方案。

導入 CSS 文件

在TypeScript文件中導入和利用CSS的目的是為了盡可能地貼近標準,在整個DevTools中執行一致性,并避免在我們的HTML中重復CSS。我們還希望能夠選擇一個解決方案,使我們的變化能夠遷移到新的網絡平臺標準,如CSS模塊腳本。

由于這些原因,@import語句和標簽似乎并不適合DevTools。它們與DevTools其他部分的導入不一致,會導致Flash Of Unstyled Content(FOUC)的出現。遷移到CSS模塊腳本會更難,因為導入必須明確地添加,并且與標簽的處理方式不同。

  1. const output = LitHtml.html` 
  2. <style> @import "css/styles.css"; </style> 
  3. <button> Hello world </button>` 
  1. const output = LitHtml.html` 
  2. <link rel="stylesheet" href="styles.css"
  3. <button> Hello World </button>` 

總結的話,潛在的解決方案是使用@import或。

相反,我們選擇找到一種方法,將CSS文件作為CSSStyleSheet對象導入,這樣我們就可以使用其adoptedStyleSheets屬性將其添加到Shadow Dom(DevTools使用Shadow DOM已經有幾年了)。

至于Shadow DOM 不清楚的,可以參考:https://developers.google.com/web/fundamentals/web-components/shadowdom

使用 CSS 的新基礎架構

我們需要一種將 CSS 文件轉換為CSSStyleSheet對象的方法,以便我們可以輕松地在 TypeScript 文件中對其進行操作。最后選擇放棄Rollup和webpack做轉化,可能考慮的原因在于,構建過程中,將任何一個bundler 添加到生產構建中都可能存在潛在的性能問題。

我們與Chromium的GN構建系統的整合使得捆綁更加困難,因此捆綁器往往不能很好地與當前的Chromium構建系統整合。

相反,我們探索了使用當前 GN 構建系統為我們進行這種轉換的選項。

新的解決方案涉及到使用adoptedStyleSheets向特定的Shadow DOM添加樣式,同時使用GN構建系統來生成可被文檔或ShadowRoot采用的CSSStyleSheet對象。

  1. // CustomButton.ts 
  2.  
  3. // Import the CSS style sheet contents from a JS file generated from CSS 
  4. import customButtonStyles from './customButton.css.js'
  5. import otherStyles from './otherStyles.css.js'
  6.  
  7. export class CustomButton extends HTMLElement{ 
  8.   …  
  9.   connectedCallback(): void { 
  10.     // Add the styles to the shadow root scope 
  11.     this.shadow.adoptedStyleSheets = [customButtonStyles, otherStyles]; 
  12.   } 

使用adoptedStyleSheets有多種好處,包括:

  • 它正在成為一個現代的標準。
  • 防止重復的CSS。
  • 只對Shadow DOM應用樣式,這就避免了CSS文件中重復的類名或ID選擇器引起的問題。
  • 易于遷移到未來的網絡標準,如CSS模塊腳本和導入斷言。

該解決方案的唯一注意事項是,導入語句需要導入.css.js文件。為了讓GN在構建過程中生成一個CSS文件,我們編寫了generate_css_js_files.js腳本。構建系統現在處理每一個CSS文件,并將其轉換為一個JavaScript文件,該文件默認導出一個CSSStyleSheet對象。因為我們可以導入CSS文件并輕松地采用它。此外,我們現在還可以輕松地對生產構建進行最小化,節省文件大小。

iconButton.css.js 生成的例子:

  1. const styles = new CSSStyleSheet(); 
  2. styles.replaceSync( 
  3.   // In production, we also minify our CSS styles 
  4.   /`${isDebug ? output : cleanCSS.minify(output).styles} 
  5.   /*# sourceURL=${fileName} */`/ 
  6. ); 
  7.  
  8. export default styles; 

后續計劃

到目前為止,Chromium DevTools 中的所有 Web 組件都已遷移到使用新的 CSS 基礎架構,而不是使用內聯樣式。大多數遺留用法registerRequiredCSS也已遷移到使用新系統。剩下的就是刪除盡可能多的module.json文件,然后遷移當前的基礎架構以在未來實現 CSS 模塊腳本!

參考

[1]https://developer.chrome.com/blog/modernising-css-infra-in-devtools/

[2]https://source.chromium.org/chromium/chromium/src/+/main:third_party/devtools-frontend/src/front_end/ui/legacy/Treeoutline.ts

[3] https://developer.chrome.com/blog/migrating-to-web-components

 

責任編輯:姜華 來源: 天天Up
相關推薦

2022-01-11 20:42:28

CSS Chrome瀏覽器

2014-06-17 14:01:34

Mysql網站架構

2019-07-04 13:05:18

MySQL設計數據庫

2015-03-02 10:02:56

云端DevOpsSOA云管理工具

2016-08-08 13:59:02

MySQL架構數據庫

2021-04-20 14:57:20

架構運維技術

2022-07-04 08:14:24

架構演變Tomcat容器架構

2022-11-15 17:31:35

邊緣計算架構人工智能

2023-10-26 11:13:31

2020-08-05 08:23:19

架構Java微服務

2010-09-08 15:16:46

clearCSS

2010-09-09 16:54:05

CSSclear

2009-08-26 18:20:42

三層架構

2020-10-28 09:12:48

React架構Hooks

2022-01-10 14:09:47

供應鏈安全分析技術網絡安全

2024-05-10 09:36:36

架構消息隊列

2022-11-14 08:32:51

CSS組件Box

2022-09-02 09:01:36

ChromeWeb調試

2012-07-09 09:08:57

傳統商業模式

2021-11-09 14:33:12

人工智能AI深度學習
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 黄色一级大片在线免费看产 | 激情婷婷| 欧美日韩不卡合集视频 | 国产第二页 | 91麻豆精品一区二区三区 | 91免费看片 | 亚洲综合无码一区二区 | 欧美精品中文字幕久久二区 | 亚洲精品免费观看 | 国产视频福利在线观看 | 亚洲成人av | 在线播放国产一区二区三区 | 日韩精品一区二区三区高清免费 | 精品国产欧美 | 日本久久久久久 | 国产精品99久久久久久人 | avmans最新导航地址 | 国产美女特级嫩嫩嫩bbb片 | 国产精品中文字幕一区二区三区 | 国产区精品在线观看 | 婷婷久久网 | 蜜桃传媒av| 亚洲一区二区三区在线 | 国产精品一区二区三级 | 亚洲视频一区二区三区 | 午夜理伦三级理论三级在线观看 | 黄色激情毛片 | 高清久久久 | 日韩中文在线 | 精品国产乱码久久久久久丨区2区 | 99re6在线视频精品免费 | 亚洲精品免费观看 | 日本久久www成人免 成人久久久久 | 国产一二三区电影 | 国产精品视频偷伦精品视频 | 国产精品久久久久久吹潮 | 亚洲区一区二区 | 天堂久久一区 | 日本a级大片 | 高清视频一区二区三区 | 日韩激情网 |