浏览器支持原生嵌套了!

9,794次阅读
没有评论

共计 608 个字符,预计需要花费 2 分钟才能阅读完成。

前言

之前在 LESS、SASS 等预处理器中嵌套写法,现在原生 css 竟然支持了哈,从 chrome112 开始支持!下面尝鲜看看语法!

CSS 原生嵌套语法

div {&> p {color: red;}

    &:hover {color: yellow;}
}

其语法规则大致如下:

parentRule {
  /* parent rule style properties */
  & childRule {/* child rule style properties */}
}

注意点

CSS Haorooms

上面的 html 这么写没有问题

div {
    border: 1px solid #000;

    .g-h3 {
        color: red;

        .g-span {color: blue;}
    }
}

假如如下:

div {
    border: 1px solid #000;

    h3 {
        color: red;

        span {color: blue;}
    }
}

这么写不生效。需要如下写法

div {
    border: 1px solid #000;

    & h3 {
        color: red;

        & span {color: blue;}
    }
}

在嵌套中使用伪元素和伪类

div {
  /* ... */
  &:hover {color: red;}

  &:is(.content, footer) {padding: 16px;}

  &::before {
    content: "";
    /* ... */
  }
}

这个写法和 css 预处理器一样的。

小结

css 支持原生嵌套功能很强大,基本可以替代 sass 和 less,但是注意的是要用 class 类,纯标签的化,需要 &

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于1970-01-01发表,共计608字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)