- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下 SCSS 用于在我的菜单中设置链接样式:
nav {
ul {
li {
a {
color: red
}
}
}
ul.opened {
li {
a {
color: green
}
}
}
}
生成以下(正确的)CSS:
nav ul li a {
color: red;
}
nav ul.opened li a {
color: green;
}
我尝试修改我的 JavaScript 以将类应用于 nav 元素,并在 Sass 中使用 selector-append()
来附加类。但这似乎以错误的顺序进行附加(如果参数颠倒,则该类附加到最后一个元素!):
nav {
ul {
li {
a {
color: red;
@at-root #{selector-append('.opened', &)} {
color: green;
}
}
}
}
}
输出(不正确!):
nav ul li a {
color: red;
}
.openednav ul li a {
color: green;
}
有没有一种方法可以重写 SCSS,以便可以正确地附加类而不必复制选择器(类似于 selector-append()
方法)?
最佳答案
因为我们要替换的元素有一个唯一的名字,所以我们要找的是这个:
nav {
ul {
li {
a {
color: red;
@at-root #{selector-replace(&, 'ul', 'ul.opened')} {
color: green;
}
}
}
}
}
操纵选择器非常脏,除非万不得已,否则我建议不要这样做。如果你通过指定诸如 table tr td
或 ul li
之类的东西来过度限定你的选择器,那么从简化开始:tr 和 ul 在这些选择器中都是多余的(除非你'试图避免在有序列表下设置样式元素)。调整您的嵌套以使其更简单等。
从 Sass 3.4 版开始,有 2 个重要的功能允许您修改选择器。
例子:
.foo ul > li a, .bar {
$sel: &;
@debug $sel;
}
你总是会得到一个字符串列表,因为选择器可以用逗号链接在一起,即使你只有一个选择器也是如此。
.foo ul > li a, .bar { ... }
(1 2 3 4 5), (1)
你会注意到后代选择器在这里被计算在内(Sass 中的列表可以用空格或逗号分隔)。记住这一点非常重要。
selector-replace()
不起作用时selector-replace()
函数在以下情况下不起作用:
ul ul li
)ul ul li
-> ul ul ul li
)ul > li
-> ul li
)在这种情况下,您需要遍历选择器并且需要知道要修改哪个位置。以下函数将采用一个函数,并使用 call() function 的魔力将其应用于选择器中的特定位置。 .
@function selector-nth($sel, $n, $f, $args...) {
$collector: ();
@each $s in $sel {
$modified: call($f, nth($s, $n), $args...);
$collector: append($collector, set-nth($s, $n, $modified), comma);
}
@return $collector;
}
我们在这里需要的函数有 2 个参数:原始选择器和您要附加到它的选择器。使用简单的插值来完成这项工作。
@function append-class($a, $b) {
@return #{$a}#{$b};
}
.foo, .bar {
ul > li a {
color: red;
@at-root #{selector-nth(&, -2, append-class, '.baz')} {
color: blue;
}
}
}
输出:
.foo ul > li a, .bar ul > li a {
color: red;
}
.foo ul > li.baz a, .bar ul > li.baz a {
color: blue;
}
这个函数也有 2 个参数:原始选择器和你想在它之前插入的选择器。
@function insert-selector($a, $b) {
@return $b $a;
}
.foo, .bar {
ul > li a {
color: red;
@at-root #{selector-nth(&, -2, insert-selector, '.baz')} {
color: blue;
}
}
}
输出:
.foo ul > li a, .bar ul > li a {
color: red;
}
.foo ul > .baz li a, .bar ul > .baz li a {
color: blue;
}
删除选择器就像用空字符串替换选择器一样简单。
@function remove-selector($sel) {
@return '';
}
.foo, .bar {
ul > li a {
color: red;
@at-root #{selector-nth(&, -2, remove-selector)} {
color: blue;
}
}
}
输出:
.foo ul > li a, .bar ul > li a {
color: red;
}
.foo ul > a, .bar ul > a {
color: blue;
}
选择器只是一个列表。任何列表操作函数都适用于它,您可以遍历它以根据需要对其进行修改。
所以,是的,除非你真的真的需要,否则不要这样做。如果您决定仍然需要它,我已将这些功能打包到 selector-nth library 中.
关于sass - 在 Sass 中修改选择器的中间部分(添加/删除类等),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28745038/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!