- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个生成的 html 代码如下。
经验法则:
1)这个html的结构无法修改,因为它是框架自己生成的html代码。
2) 只有纯 css 解决方案。
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="inactive"></span>
<span class="inactive"></span>
</div>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="active"><span>This is active class 2</span></span>
<span class="inactive"></span>
</div>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="active"><span>This is active class 2</span></span>
<span class="active"><span>This is active class 3</span></span>
</div>
<div class="wrapper">
<span class="inactive"><span></span></span>
<span class="active"><span>This is active class 2</span></span>
<span class="active"><span>This is active class 3</span></span>
</div>
我打算实现的目标:
逗号分隔符如下。
This is active class 1.
This is active class 1, this is active class 2.
This is active class 1, this is active class 2, this is active class 3.
This is active class 2, this is active class 3.
但是我目前的结果好像不能得到这个。我正在尝试搜索 last-of-class css 选择器(对我来说,如果这个选择器存在,一切都会被简化)但似乎没有这样的 css 选择器。但我想不出 css 逻辑来解决。希望有人能提供帮助。
如果最后一个类 css 存在,我的方法:
.wrapper span > span::after {
content: ',';
}
.wrapper span:last-child > span::after {
content: '.';
}
.wrapper span.active:last-of-class > span::after {
content:'.';
}
最佳答案
使用::before
代替::after
;现在我们只需要删除第一个事件的子逗号,当它是奇数和偶数时。
::before
给每个跨度一个逗号(除非它是第一个 child )::after
给最后一个跨度加上句号。.wrapper > span:not(:first-child) > span::before {
content: ', ';
}
.wrapper > span.inactive:first-child + span.inactive + span.active > span::before,
.wrapper > span.inactive:first-child + span.active > span::before {
content: '';
}
对于这个例子,display: flex
移除了行内间隙,white-space: nowrap
防止它们在到达视口(viewport)边缘时换行。
.wrapper {
display: flex;
white-space: nowrap;
}
.wrapper > span:last-child::after {
content: '.';
}
.wrapper > span:not(:first-child) > span::before {
content: ', ';
}
.wrapper > span.inactive:first-child + span.inactive + span.active > span::before,
.wrapper > span.inactive:first-child + span.active > span::before {
content: '';
}
<h2>Random examples</h2>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="active"><span>This is active class 2</span></span>
<span class="active"><span>This is active class 3</span></span>
<span class="active"><span>This is active class 4</span></span>
<span class="active"><span>This is active class 5</span></span>
<span class="active"><span>This is active class 6</span></span>
<span class="active"><span>This is active class 8</span></span>
<span class="active"><span>This is active class 9</span></span>
<span class="active"><span>This is active class 10</span></span>
</div>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 3</span></span>
<span class="active"><span>This is active class 4</span></span>
<span class="inactive"></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 8</span></span>
<span class="active"><span>This is active class 9</span></span>
<span class="inactive"></span>
</div>
<div class="wrapper">
<span class="inactive"></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 3</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 5</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 9</span></span>
<span class="active"><span>This is active class 10</span></span>
</div>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 3</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 5</span></span>
</div>
<div class="wrapper">
<span class="inactive"></span>
<span class="active"><span>This is active class 2</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 4</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 6</span></span>
<span class="inactive"></span>
<span class="active"><span>This is active class 9</span></span>
<span class="inactive"></span>
</div>
<h2>
Your examples
</h2>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="inactive"></span>
<span class="inactive"></span>
</div>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="active"><span>This is active class 2</span></span>
<span class="inactive"></span>
</div>
<div class="wrapper">
<span class="active"><span>This is active class 1</span></span>
<span class="active"><span>This is active class 2</span></span>
<span class="active"><span>This is active class 3</span></span>
</div>
<div class="wrapper">
<span class="inactive"><!--<span>This Shouldn't be here, right?</span>--></span>
<span class="active"><span>This is active class 2</span></span>
<span class="active"><span>This is active class 3</span></span>
</div>
关于html - CSS3 逗号分隔列表(nth-of-class),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38886763/
我正在尝试从下拉列表中创建一个多选复选框,并通过 ; 连接所选结果。 我的代码是这样的: var myobject = { ValueA : 'Text A', ValueB : 'T
我有输入,我需要获取值并用 “|” 符号分隔。 我的输入: 输出我需要的: 00:00|00:00|00:00 我的代码是: (而且它不工作) var timesArray = $('table').
我正在尝试将超过 400 万行的列拆分为 4 个新列,问题是我不知道在哪里查看或我应该使用 Google 搜索哪个术语。 (是的,我已经在 Google 和 Stack 中搜索了一个类似的问题,但只在
我有一个很大的 csv 文件,其中充满了用“|”分隔的数字字符,例如: 432452 | 543634 4122442 | 41256512 64523 | 12416 然后我读入数据如下: fs
我有一个程序可以计算多个数字的阶乘。这些数字在 cmd 中作为参数传递: factorial.exe 3 4 5 这将分别计算 3、4 和 5 的阶乘。该程序的早期版本有一个百分比显示堆栈的完整性。我
这个问题已经有答案了: 奥 git _a (6 个回答) 已关闭 9 年前。 我有一个双数“547.123456” 我只想使用这个 double 作为“547.1”,就像“.”后面只有 1 个数字 我
我有一个程序可以计算多个数字的阶乘。这些数字在 cmd 中作为参数传递: factorial.exe 3 4 5 这将分别计算 3、4 和 5 的阶乘。该程序的早期版本有一个百分比显示堆栈的完整性。我
我有一个 ArrayList,其中包含一个 messageId、一个 -、一个用户名。 示例:E123-sam 我想划分 List 的每个元素,使得 - 之前的部分进入一个 ArrayList ,而之
我目前有一个“日期”列作为 pandas 数据框的索引,其格式为: January February .... Year2 January February ... Year3 (它来自 pdf 表格
我正在尝试对我的 .mdb 数据库进行 ODBC 查询。我正在使用 mdbtools 驱动程序。该代码是使用 Eclipse 用 C 语言编写的。唯一的问题是,当我写例如: "SELECT 'last
我需要知道如何将这两个if else 部分分开。 public static int NextBday(int Bdays, int days){ int daysleft = 0;
我想计算我的员工分开但合并在一起的出勤率 My target output 我的代码 SELECT count(employees_id) as numbers FROM attendance WH
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 7 年前。 Improve t
下面是我的代码的一小段摘录,它从 API 添加了一行。总共有很多行。 每一行包含一行数据如 TY8tr,50,34,P,SB, 数据行在数据类型上是一致的。我如何通过 ,'s 拆分数组列表中
我想获取选中的元素并用逗号分隔它们,最后一个元素用“and”分隔 它的显示输出为: 我想删除最后一个元素后面的逗号 (,) 并在它前面添加 'and',例如 Sugar, Milk and Extra
我是 JSON 的新手,但在从已解析的 JSON 对象中提取数据时遇到问题: 我有一个 getstats.php 文件,它回显 mysql 查询的 json 编码结果。以下是 php 文件返回的示例:
我有一个像这样的数字/字符串(我不确定如何将 int 与字符串相互转换) 000000122310200000223340000700012220000011411000000011011271043
标签内的文本
我想尝试一些基本的网络抓取,但遇到了一个问题,因为我习惯了简单的 td-tags,在这种情况下,我有一个网页,其中包含以下预标记和其中的所有文本,这意味着刮掉它有点棘手。 11111111 1111
出于练习目的,我正在开发 TCP 客户端/服务器系统,我想在两者之间发送特定数据。 我已经能够发送字节并让它们显示为字符串。此外,我还可以发送一个特定的字符串(“mb”)并在服务器端弹出一个 Mess
在大量的 unicode 字符中,有一些实际上表示多个字符,例如两个 'f' 字符的 U+FB00 连字 ff。有什么方法可以轻松地将这样的字符转换为多个单个字符?最好是标准 Java API 中可用
我是一名优秀的程序员,十分优秀!