新聞中心
你好,我是小弋。

創(chuàng)新互聯(lián)專注于企業(yè)網(wǎng)絡(luò)營銷推廣、網(wǎng)站重做改版、寶塔網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5高端網(wǎng)站建設(shè)、商城網(wǎng)站建設(shè)、集團公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為寶塔等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
這片文章描述了DevTools 架構(gòu)在CSS層面所做的更改。
本文主要解釋 CSS 在歷史上如何在 DevTools 中工作,以及如何在 DevTools 中現(xiàn)代化我們的 CSS,以準(zhǔn)備(最終)遷移到用于在 JavaScript 文件中加載 CSS 的 Web 標(biāo)準(zhǔn)解決方案。
DevTools 中 CSS 的先前狀態(tài)
DevTools 以兩種不同的方式實現(xiàn) CSS:
- 一種用于DevTools遺留部分中使用的 CSS 文件
- 另一種用于 DevTools 中使用的現(xiàn)代 Web 組件。
對于第一種遺留部分的來說,我們翻開Chromium源碼,可以大致猜想它的實現(xiàn):
Chromium源碼
DevTools 中的 CSS 實現(xiàn)是多年前定義的,現(xiàn)在已經(jīng)過時了。DevTools 一直堅持使用該module.json模式,
那么我們來看下這個文件具體形式是如何的:
module.json
這些CSS文件會被放在同一個目錄下,為了將添加到 DevTools,您需要registerRequiredCSS使用要加載的文件的確切路徑進行調(diào)用。
那么它的調(diào)用如下:
- constructor() {
- …
- this.registerRequiredCSS('ui/legacy/components/quick_open/filteredListWidget.css');
- …
- }
通過檢索CSS文件的內(nèi)容后,通過appendStyle函數(shù)將內(nèi)容插入到
- const output = LitHtml.html`
- `
總結(jié)的話,潛在的解決方案是使用@import或。
相反,我們選擇找到一種方法,將CSS文件作為CSSStyleSheet對象導(dǎo)入,這樣我們就可以使用其adoptedStyleSheets屬性將其添加到Shadow Dom(DevTools使用Shadow DOM已經(jīng)有幾年了)。
至于Shadow DOM 不清楚的,可以參考:https://developers.google.com/web/fundamentals/web-components/shadowdom
使用 CSS 的新基礎(chǔ)架構(gòu)
我們需要一種將 CSS 文件轉(zhuǎn)換為CSSStyleSheet對象的方法,以便我們可以輕松地在 TypeScript 文件中對其進行操作。最后選擇放棄Rollup和webpack做轉(zhuǎn)化,可能考慮的原因在于,構(gòu)建過程中,將任何一個bundler 添加到生產(chǎn)構(gòu)建中都可能存在潛在的性能問題。
我們與Chromium的GN構(gòu)建系統(tǒng)的整合使得捆綁更加困難,因此捆綁器往往不能很好地與當(dāng)前的Chromium構(gòu)建系統(tǒng)整合。
相反,我們探索了使用當(dāng)前 GN 構(gòu)建系統(tǒng)為我們進行這種轉(zhuǎn)換的選項。
新的解決方案涉及到使用adoptedStyleSheets向特定的Shadow DOM添加樣式,同時使用GN構(gòu)建系統(tǒng)來生成可被文檔或ShadowRoot采用的CSSStyleSheet對象。
- // CustomButton.ts
- // Import the CSS style sheet contents from a JS file generated from CSS
- import customButtonStyles from './customButton.css.js';
- import otherStyles from './otherStyles.css.js';
- export class CustomButton extends HTMLElement{
- …
- connectedCallback(): void {
- // Add the styles to the shadow root scope
- this.shadow.adoptedStyleSheets = [customButtonStyles, otherStyles];
- }
- }
使用adoptedStyleSheets有多種好處,包括:
- 它正在成為一個現(xiàn)代的標(biāo)準(zhǔn)。
- 防止重復(fù)的CSS。
- 只對Shadow DOM應(yīng)用樣式,這就避免了CSS文件中重復(fù)的類名或ID選擇器引起的問題。
- 易于遷移到未來的網(wǎng)絡(luò)標(biāo)準(zhǔn),如CSS模塊腳本和導(dǎo)入斷言。
該解決方案的唯一注意事項是,導(dǎo)入語句需要導(dǎo)入.css.js文件。為了讓GN在構(gòu)建過程中生成一個CSS文件,我們編寫了generate_css_js_files.js腳本。構(gòu)建系統(tǒng)現(xiàn)在處理每一個CSS文件,并將其轉(zhuǎn)換為一個JavaScript文件,該文件默認(rèn)導(dǎo)出一個CSSStyleSheet對象。因為我們可以導(dǎo)入CSS文件并輕松地采用它。此外,我們現(xiàn)在還可以輕松地對生產(chǎn)構(gòu)建進行最小化,節(jié)省文件大小。
iconButton.css.js 生成的例子:
- const styles = new CSSStyleSheet();
- styles.replaceSync(
- // In production, we also minify our CSS styles
- /`${isDebug ? output : cleanCSS.minify(output).styles}
- /*# sourceURL=${fileName} */`/
- );
- export default styles;
后續(xù)計劃
到目前為止,Chromium DevTools 中的所有 Web 組件都已遷移到使用新的 CSS 基礎(chǔ)架構(gòu),而不是使用內(nèi)聯(lián)樣式。大多數(shù)遺留用法registerRequiredCSS也已遷移到使用新系統(tǒng)。剩下的就是刪除盡可能多的module.json文件,然后遷移當(dāng)前的基礎(chǔ)架構(gòu)以在未來實現(xiàn) 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
分享文章:CSS在DevTools中架構(gòu)演變?
當(dāng)前URL:http://www.dlmjj.cn/article/djopioh.html


咨詢
建站咨詢
