CSS 预处理器和父选择器

发布于 2021-07-04 21:23:30 字数 3247 浏览 1204 评论 0

Web 网站和 web app 开发对 RTL(right-to-left,从右向左的阅读顺序)是非常头疼的,因为我们没有相应的CSS属性或者是现有的CSS属性在各个浏览器兼容性太差,导致不能够让网站和网页应用正确地展示”RTL”。虽然现有一些属性比如 text-align:start; 和 -moz-margin-star 都支持 RTL,但是他们都不能兼容所有的浏览器.然而大家都知道多国语言版的网站对于”RTL”的支持也是重要的工作之一。

难道我们最终只能这样做?给选择器添加一个支持 RTL 的样式,有的时候还需要添加少许偏移。

/* ltr / default */
.some {
    .thing {
        > .is {
            .here {
                margin-left: 20px;
            }
        }
    }
}

/* rtl */
html[dir=rtl] {
    .some {
        .thing {
            > .is {
                .here {
                    margin-right: 20px;
                    margin-left: 0;
                }
            }
        }
    }
}

我认为这样写生不如死,有下面这些理由:

  • 如果你需要更改默认嵌套的CSS结构,你也必须记得将这些单独RTL模块分开。
  • 如果你需要去改变原来的规则,你也必须记得去改变以前的 RTL模块,然后再设置一个新的规则。

在 Stylus 中,我发现了一个很好的解决方案,用一个简单的 mixin 一解决这结问题。

/* mixin definition ; sets LTR and RTL within the same style call*/
bidi-style(prop, value, inverse-prop, default-value) {
    {prop}: value;

    html[dir=rtl] & {
        {inverse-prop}: value;
        {prop}: default-value;
    }
}

/* usage */
.some {
    .thing {
        > .is {
            .here {
                bidi-style(margin-left, 20px, margin-right, 0); /* setting LRT and RTL! */
            }
        }
    }
}

上面这个 mixin 十分简单,但是让我为之兴奋。相比于机械地复制和频繁地重写内嵌结构,这种混合类能让我设置 RTL 的属性和值在代码中相同的位置,从而避免去创建单独的 RTL 模块,在这个方案中,根据文字方向可以简单的置换出相关属性,基本上覆盖了 95% 的情景。

我也知道 LESS 也包含了这种模式,但是我不确定SASS也能这样做。不错的是,RTL 并不是唯一一个能完美应用这个方案的例子。同时,你也可以用这种方法写一些基本特征的元素像 Modernizr CSS 的类一样:

.gradient-background {
    background-image: linear-gradient(top, #555, #333);

    .no-cssgradients & {
        background: url("background.png")
    }
}

这个简单的结构让写 CSS 和组织不同状态时容易了1百万倍.在理想的情况下,start 的属性和值会被增加,但是在这之前没有,用这种写法会让你的生活更轻松。

补充说明

以下部分内容来自于自我整理的。

文中主要介绍了的如何在CSS预处理器语言中使用父选择器。其实在Sass中,同样具有这样的功能,我们来看一个简单的例子,即将文中 Stylus 的代码转换成 Sass 的处理方式,具体代码如下所示:

@mixin bidi-style($prop,$value,$inverse-prop,$default-value){
    #{$prop}: $value;
    html[dir=rtl] & {
        #{$inverse-prop}: $value;
        #{$prop}: $default-value;
    }
}

.some {
    .thing {
        > .is {
            .here {
                @include bidi-style(margin-left,20px,margin-right,0);
            }
        }
    }
}

经过命令编译出来以后的 CSS 代码如下:

.some .thing > .is .here {
  margin-left: 20px; }
  html[dir=rtl] .some .thing > .is .here {
    margin-right: 20px;
    margin-left: 0; }

不过在 Sass 中需要特别注意 & 的运用,我们来看一个简单的案例:

.children {
    .parent & {
        color:green;
    }

    &.parent {
        color:blue;
    }

    & .parent {
        color: yellow;
    }
}

编译出来的CSS:

.parent .children {
  color: green; }
.children.parent {
  color: blue; }
.children .parent {
  color: yellow; }

我想从上面这个简单的案例中,在Sass中如何运用 & 符实现父选择器嵌套,你已有一个更形象的理解。如果您对这方面还有更好的建议,不仿在下面的评论中与我们分享。

英文原文:http://davidwalsh.name/stylus-parent-selectors

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

虐人心

有一天你能到我的心里去,你会看到那里全是你给的伤悲。

文章
评论
24518 人气
更多

推荐作者

夢野间

文章 0 评论 0

doggiejohn

文章 0 评论 0

就此别过

文章 0 评论 0

初见终念

文章 0 评论 0

qq_rvKjBH

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文