精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

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瀏覽器

2019-07-04 13:05:18

MySQL設計數據庫

2014-06-17 14:01:34

Mysql網站架構

2015-03-02 10:02:56

云端DevOpsSOA云管理工具

2016-08-08 13:59:02

MySQL架構數據庫

2022-07-04 08:14:24

架構演變Tomcat容器架構

2021-04-20 14:57:20

架構運維技術

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

2022-01-10 14:09:47

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

2009-08-26 18:20:42

三層架構

2020-10-28 09:12:48

React架構Hooks

2024-05-10 09:36:36

架構消息隊列

2022-09-02 09:01:36

ChromeWeb調試

2022-11-14 08:32:51

CSS組件Box

2021-11-09 14:33:12

人工智能AI深度學習

2012-07-09 09:08:57

傳統商業模式
點贊
收藏

51CTO技術棧公眾號

日韩精品亚洲专区在线观看| av亚洲在线| 99国内精品久久久久| 亚洲欧洲日韩女同| 国产精品加勒比| 精品欧美一区二区三区免费观看 | 亚洲影视一区| 亚洲第一精品自拍| 污污动漫在线观看| 精品人妻互换一区二区三区| 貂蝉被到爽流白浆在线观看| 综合欧美精品| 亚洲成人7777| 亚洲欧美99| 亚洲国产精品久久久久爰性色 | 亚洲AV无码国产精品午夜字幕| 在线亚洲激情| 久久天天躁狠狠躁夜夜躁2014 | 欧美人与动xxxxz0oz| 欧美在线影院一区二区| 精品久久久久久无码中文野结衣| 一级特黄妇女高潮| 性高潮久久久久久| 久久男人天堂| 亚洲欧美偷拍卡通变态| 欧美成ee人免费视频| av中文字幕播放| 久久综合中文| 日韩欧美亚洲一区二区三区| 国产黄色一级大片| 久久综合九色综合欧美狠狠| www.日韩欧美| 一区二区视频观看| 中文字幕一区二区三区中文字幕| 日本韩国一区二区三区视频| 中文字幕无码精品亚洲资源网久久| 阿v免费在线观看| 成人av在线影院| 成人av在线电影| 日韩美女一区二区三区四区| 能在线观看的av网站| 91福利区在线观看| 亚洲卡通动漫在线| 亚洲最新免费视频| 爱久久·www| 久久精品在线免费观看| 精品视频导航| 欧美一区二区黄片| 高清不卡在线观看| 91精品国自产在线观看| 一区二区三区黄色片| 视频在线观看国产精品| 欧美一级大片视频| 黄网在线观看视频| 99热这里只有成人精品国产| 久久久在线视频| 日本黄色小说视频| 欧美.www| 欧美国产日韩一区二区| 婷婷色中文字幕| 真实国产乱子伦精品一区二区三区| 日韩中文字幕在线精品| 91av手机在线| 91精品啪在线观看国产18| 久久视频免费观看| 青娱乐国产在线视频| 在线国产欧美| 91高潮在线观看| 黑人精品无码一区二区三区AV| 久久aⅴ乱码一区二区三区| 欧美一区二区影院| www.欧美色| 毛片av一区二区| 91久久嫩草影院一区二区| 99久久久久久久| 成人永久免费视频| 久中文字幕一区| 成年人免费在线视频| 亚洲欧洲一区二区在线播放| 欧美日韩激情四射| 国产在线精彩视频| 欧美午夜在线一二页| 九九九九九九九九| 国产精品久久久网站| 亚洲乱码国产乱码精品精| 国产aaaaaaaaa| 欧美/亚洲一区| 欧洲永久精品大片ww免费漫画| 自拍偷拍校园春色| 精品一二三四在线| 国产呦系列欧美呦日韩呦| 精品久久av| 一区二区国产视频| 成人黄色一区二区| 久久视频社区| 精品视频在线播放免| 可以免费看av的网址| 国内精品久久久久久久影视蜜臀| 日韩av电影在线网| 国产夫妻自拍av| 久久亚洲精品小早川怜子| 一区二区视频在线免费| 51精品视频| 欧美久久久一区| 影音先锋黄色资源| 一本一道久久a久久精品蜜桃| 91大神福利视频在线| 国产一区二区在线视频观看| 97超碰欧美中文字幕| 中文字幕在线中文字幕日亚韩一区| 久久大胆人体| 欧美久久免费观看| 日韩人妻一区二区三区| 欧美 日韩 国产一区二区在线视频 | 日韩欧美一区二区三区在线视频| 韩国三级日本三级少妇99| 一区精品在线观看| 91视视频在线直接观看在线看网页在线看 | 丁香六月色婷婷| 国产精品欧美久久久久一区二区| 黄色大片中文字幕| 国产精选久久| 最近中文字幕mv在线一区二区三区四区| 日韩大片免费在线观看| 国产乱码精品一品二品| 先锋影音亚洲资源| 亚洲va中文在线播放免费| 精品福利一区二区三区| 校园春色 亚洲| 久久福利资源站| 日韩免费av一区二区三区| www.超碰在线| 亚洲福利在线视频| 欧美成人精品欧美一级私黄| 久久99久久99小草精品免视看| 欧美极品一区| 天堂中文av在线资源库| 亚洲第一精品福利| 日韩欧美亚洲一区二区三区| 成人av资源网站| 国产乱子伦精品无码专区| 麻豆国产一区| 精品视频9999| 99视频在线观看免费| 日韩一区在线看| 三级一区二区三区| 国产精品99视频| 国产又爽又黄的激情精品视频| √新版天堂资源在线资源| 欧美在线观看视频一区二区三区| 手机免费看av| 三级久久三级久久久| 日韩videos| 精品三区视频| x99av成人免费| 国产毛片久久久久| 亚洲精品国产精华液| 蜜桃视频无码区在线观看| 91精品国产视频| 99伊人久久| 激情网站在线| 日韩第一页在线| chinese国产精品| 中文字幕免费不卡在线| 日韩av片免费观看| 黄色免费成人| 全部毛片永久免费看| 麻豆视频网站在线观看| 欧洲视频一区二区| www..com.cn蕾丝视频在线观看免费版| 亚洲欧美不卡| 欧美高清视频www夜色资源网| 扒开jk护士狂揉免费| 日日摸夜夜添夜夜添亚洲女人| 日韩午夜视频在线观看| 久久人体av| 欧美成人一二三| 色综合视频在线| 在线观看一区日韩| 手机在线免费看片| 成人美女视频在线看| 无码人妻丰满熟妇区毛片18| 成人激情免费视频| 91夜夜揉人人捏人人添红杏| 91美女主播在线视频| 国产香蕉精品视频一区二区三区| 一区二区三区精| 午夜在线成人av| 久久丫精品忘忧草西安产品| 国产一区激情在线| 黄色国产一级视频| 色777狠狠狠综合伊人| av资源站久久亚洲| 亚洲综合av一区二区三区| 久久69精品久久久久久久电影好| 五月天婷婷社区| 欧美人动与zoxxxx乱| 国产成人啪精品午夜在线观看| 深夜福利亚洲| 国产精品亲子乱子伦xxxx裸| 亚洲最大视频网| 久久经典综合| 热久久最新网址| 久草成人在线| 91九色极品视频| 欧美特大特白屁股xxxx| 欧美成人激情在线| 精品av中文字幕在线毛片| 51久久夜色精品国产麻豆| 日韩成人免费观看| 亚洲天堂免费在线观看视频| 亚洲欧美日本一区| 韩国理伦片一区二区三区在线播放| 欧美深夜福利视频| 一区二区三区四区电影| 欧美一区二区三区精美影视| 4438全国亚洲精品观看视频| 国产精品激情自拍| 97超碰在线免费| 久久久99免费视频| 国产二区视频在线观看| 日韩国产一区三区| 懂色av蜜臀av粉嫩av分享吧| 欧美亚洲一区二区在线观看| 天天操天天摸天天干| 一区二区三区在线观看欧美| 丁香六月激情综合| 国产日本一区二区| 亚洲观看黄色网| 国产成+人+日韩+欧美+亚洲| 最新av免费在线观看| 日本在线播放一区二区三区| 国产精品专区在线| 欧美日韩一区二区三区四区在线观看 | 国产一级黄色录像片| 日韩在线观看一区| 秋霞久久久久久一区二区| 日韩大胆成人| 精品国产福利| 欧美日韩一区二区三区四区不卡 | 色综合久久88色综合天天| 日韩精品一区二区三区不卡 | caoporn视频在线| 精品中文字幕在线| 麻豆网在线观看| 日韩在线观看免费全| 一级毛片视频在线观看| 中文字幕欧美精品日韩中文字幕| 国产小视频免费在线网址| 亚洲精品在线观看www| 蜜桃成人在线视频| 亚洲一区av在线播放| 粉嫩av在线播放| 在线中文字幕日韩| 午夜视频成人| 久久韩剧网电视剧| 大地资源网3页在线观看| 久久久精品久久| 国产激情在线观看| 免费成人高清视频| 青青草原av在线| 国外成人性视频| 国产资源在线观看入口av| 91av在线网站| 午夜精品成人av| 国产精品久久久久久网站| 国产福利亚洲| 99视频在线播放| 日韩av影院| 日韩欧美视频一区二区三区四区 | 日韩网站在线免费观看| 亚洲视频大全| 国产裸体免费无遮挡| 极品少妇xxxx精品少妇偷拍| 一起草最新网址| 99视频一区二区| 少妇视频在线播放| 一区二区三区在线免费视频| 日韩欧美三级视频| 日本道免费精品一区二区三区| 中文字幕丰满人伦在线| 日韩一区二区三区视频| 五月婷婷六月色| 日韩中文在线视频| 日韩伦理av| 国产成+人+综合+亚洲欧洲| 四虎国产精品免费久久| 国产精品久久久久久久久久久久冷| 亚洲婷婷丁香| 黄色网络在线观看| 国产深夜精品| 色婷婷.com| 99久久婷婷国产| 啪啪一区二区三区| 亚洲sss视频在线视频| 自拍偷拍色综合| 精品久久免费看| 伊人在线视频| 2019最新中文字幕| 电影中文字幕一区二区| 久久久久高清| 综合激情一区| av免费在线播放网站| 国产成人免费视频精品含羞草妖精| 熟女俱乐部一区二区| 一区二区理论电影在线观看| 最新中文字幕第一页| 亚洲国产欧美日韩精品| 最新黄网在线观看| 国产精品久久久久久久美男| 国产香蕉精品| 中文字幕免费高| 久久一二三四| 97人妻精品一区二区三区免费| 一区在线播放视频| 精品久久久久久久久久久国产字幕| 日韩免费在线观看| 一级日本在线| 国产精品久久久久av| 欧美aaaaa级| www.avtt| 国产精品资源在线看| 亚洲色图 激情小说| 欧美日韩国产精品一区二区亚洲| 国产精品白丝jk黑袜喷水| 无码人妻精品一区二区三区温州 | avhd101老司机| 婷婷一区二区三区| 国产高清精品软件丝瓜软件| 中文字幕久久亚洲| 亚洲最大网站| 九九九九九精品| 亚洲激精日韩激精欧美精品| 视频免费1区二区三区| 日本一区免费视频| 波多野结衣一区二区三区在线 | 免费在线观看av网站| 国产成人精品在线播放| 无码日韩精品一区二区免费| 日本a在线免费观看| 粉嫩绯色av一区二区在线观看| 精品国产欧美日韩不卡在线观看| 欧美日韩视频在线一区二区| av在线电影院| 国产精品偷伦免费视频观看的| 九热爱视频精品视频| 大肉大捧一进一出好爽动态图| 久久人人97超碰com| 精品国产xxx| 亚洲人成电影网站色www| 伊伊综合在线| 日本亚洲导航| 蜜臀精品久久久久久蜜臀 | 无码人妻丰满熟妇区五十路| 国产精品日产欧美久久久久| 中国一级免费毛片| 欧美mv日韩mv国产网站app| 在线观看三级视频| 91传媒免费看| 国内精品久久久久久久影视蜜臀| 欧洲成人午夜精品无码区久久| 一区二区免费在线| 日韩在线视频免费| 欧美性视频精品| 欧美理论电影大全| 亚洲精品第三页| 亚洲成a人片| 午夜一区二区三区| 久久精品国产一区二区三| 精品在线观看一区| 欧美大片在线观看| 超碰在线cao| 日产中文字幕在线精品一区 | www.99r| 亚洲男同性视频| 日韩中文字幕免费在线观看| 色综合久久精品亚洲国产| 国产精品色呦| 国内自拍视频一区| 成人免费在线视频| 东京干手机福利视频| 国产999视频| 羞羞色午夜精品一区二区三区| 香蕉久久久久久av成人| 狠狠色狠狠色综合日日小说| √新版天堂资源在线资源| 古典武侠综合av第一页| 久久午夜激情| 18岁成人毛片| 日韩精品中文字幕视频在线| 国产精品伊人| 国产精品入口芒果| 国产精品丝袜久久久久久app| 精品美女www爽爽爽视频| 55夜色66夜色国产精品视频| 国产精品久久久久无码av| 欧美肉大捧一进一出免费视频| 欧美日韩在线精品一区二区三区激情 | 主播福利视频一区| 福利在线一区|