Css 循环中的多个选择器
我使用以下代码以较少的CSS生成列布局:Css 循环中的多个选择器,css,less,Css,Less,我使用以下代码以较少的CSS生成列布局: .columnBuilder (@index) when (@index =< @columnCount) { .container_@{columnCount} .grid_@{index} { width: unit(((@baseWidth / @columnCount) * @index)-10, px); } .columnBuilder(@index + 1); } 我现在如何创建一个新的less函数,该函数
.columnBuilder (@index) when (@index =< @columnCount) {
.container_@{columnCount} .grid_@{index} {
width: unit(((@baseWidth / @columnCount) * @index)-10, px);
}
.columnBuilder(@index + 1);
}
我现在如何创建一个新的less函数,该函数的输出为:
.grid_1,
.grid_2,
....,
.grid_N {
display: inline;
float: left;
margin-left: 5px;
margin-right: 5px;
}
.grid_1,
.grid_2,
....,
.grid_N {
display: inline;
float: left;
margin-left: 5px;
margin-right: 5px;
}
其中
N
定义为@columnCount:24代码>,虽然未设置列计数,但可以将其更改为任何数字。我知道我可以为每个grid\u X
创建一个主体,以避免混乱。事实证明,LESS对类似的东西没有本机支持,总是会创建多个CSS块,每个块都有自己的主体,所以你需要对mixin进行一点修改。我使用了以下方法:
.columnBuilderX (@index) when (@index = 1) {
@isel: ~".grid_@{index}, ";
.columnBuilderX (@index + 1, @isel);
}
.columnBuilderX (@index, @innerSel) when (@index =< (@columnCount - 1)) {
@isel: @innerSel + ~".grid_@{index}, ";
.columnBuilderX (@index + 1, @isel);
}
.columnBuilderX (@index, @innerSel) when (@index = @columnCount) {
@isel: @innerSel + ~".grid_@{index} ";
@{isel} {
display: inline;
float: left;
margin-left: 5px;
margin-right: 5px;
}
.columnBuilderX (@index + 1, @isel);
}
第一个mixin是被调用的初始mixin,它没有内部选择器,第二个mixin需要第二个param,它是我们在第一个mixin中创建的变量,然后递归运行,直到我们到达由when
子句定义的最后一列,在该子句中,我们添加了最后一个没有逗号的选择器,然后使用我们内置的选择器列表来应用CSS
如果有人能想出比这更简单的方法,请用:extend()
在1.4中创建一个答案。+
这似乎更优雅地完成了它。首先定义要在硬编码的.grid_1
类中扩展的初始值(目前,LESS不会扩展动态生成的类),然后在循环中添加扩展程序mixin以扩展到该类。像这样:
.grid_1 { //this acts as the "launch point" for extending them all
display: inline;
float: left;
margin-left: 5px;
margin-right: 5px;
}
.columnBuilder (@index) when (@index =< @columnCount) {
//we are going to use this class twice, so just calculate it once
@gridClass: ~'.grid_@{index}';
//this is your original code except the variable now used for the grid class
.container_@{columnCount} @{gridClass} {
width: unit(((@baseWidth / @columnCount) * @index)-10, px);
}
//this is your extender feature, which does not do so for the initial .grid_1
//which was set above as our launch point.
@{gridClass} {
.extender() when (@index > 1) {
&:extend(.grid_1 all);
}
.extender() when (@index = 1) {}
.extender();
}
//iterate the loop just as you were doing
.columnBuilder(@index + 1);
}
//call the loop starting at 1
.columnBuilder(1);
.grid_1 { //this acts as the "launch point" for extending them all
display: inline;
float: left;
margin-left: 5px;
margin-right: 5px;
}
.columnBuilder (@index) when (@index =< @columnCount) {
//we are going to use this class twice, so just calculate it once
@gridClass: ~'.grid_@{index}';
//this is your original code except the variable now used for the grid class
.container_@{columnCount} @{gridClass} {
width: unit(((@baseWidth / @columnCount) * @index)-10, px);
}
//this is your extender feature, which does not do so for the initial .grid_1
//which was set above as our launch point.
@{gridClass} {
.extender() when (@index > 1) {
&:extend(.grid_1 all);
}
.extender() when (@index = 1) {}
.extender();
}
//iterate the loop just as you were doing
.columnBuilder(@index + 1);
}
//call the loop starting at 1
.columnBuilder(1);
.grid_1,
.grid_2,
....,
.grid_N {
display: inline;
float: left;
margin-left: 5px;
margin-right: 5px;
}