CSS在DevTools中架构演变?

你好,我是小弋。

创新互联专注于企业网络营销推广、网站重做改版、宝塔网站定制设计、自适应品牌网站建设、H5高端网站建设商城网站建设、集团公司官网建设、外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为宝塔等各大城市提供网站开发制作服务。

这片文章描述了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.   …
  5. }

通过检索CSS文件的内容后,通过appendStyle函数将内容插入到

  • `
  •  
     
     
     
    1. const output = LitHtml.html`
    2. `

    总结的话,潜在的解决方案是使用@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. // Import the CSS style sheet contents from a JS file generated from CSS
    3. import customButtonStyles from './customButton.css.js';
    4. import otherStyles from './otherStyles.css.js';
    5. export class CustomButton extends HTMLElement{
    6.   … 
    7.   connectedCallback(): void {
    8.     // Add the styles to the shadow root scope
    9.     this.shadow.adoptedStyleSheets = [customButtonStyles, otherStyles];
    10.   }
    11. }

    使用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. 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

    网页名称:CSS在DevTools中架构演变?
    文章分享:http://www.gawzjz.com/qtweb/news47/175997.html

    网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联