不借助后台和 JS ,只用 CSS 让一个列表编号倒序

目录
文章目录隐藏
  1. HTML 中的 reversed 属性
  2. HTML 中的 value 属性
  3. CSS 自定义的 counter()
  4. 结语

我正在做一个项目,其中有一个倒序的列表。列表创建时间降序排序的,这里我想在语义和视觉上都能体现出来(让列表显示对应的编号,编号越大表示是最新的)。网上做了一些研究,找到了一些有趣的解决办法,有些很好,有些就不那么好了。

最终结果类似如下:

不借助后台和 JS ,只用 CSS 让一个列表编号倒序

接着,我们来看看有哪些实现的方式。

HTML 中的 reversed 属性

简单,最直接的解决方案是 HTML 中的reversed属性。

<ol reversed>
  <li>C</li>
  <li>B</li>
  <li>A</li>
</ol>

效果如下:

HTML 中的 reversed 属性

reversed 属性是一个布尔属性,reversed 属性规定列表顺序为降序 (9, 8, 7…),而不是升序 (1, 2, 3…)。

reversed 属性除了 IE 大多数的浏览器都支持,如果你只想要解决方法,用这种就够了。

如果你好奇还有哪些实现方式,请继续阅读。

HTML 中的 value 属性

另一种方法就是使用 value 属性:

<ol>
  <li value="3">C</li>
  <li value="2">B</li>
  <li value="1">A</li>
</ol>

效果如下:

HTML 中的 reversed 属性

这种方式虽然比较冗长,但我们对列表也有更多控制权,比如,我们还可以这样操作:

<ol>
  <li value="6">C</li>
  <li value="4">B</li>
  <li value="2">A</li>
</ol>

效果如下:

HTML 中的 value 属性

最好还是不要这样做,因为跳过数字可能会让用户感到困惑。

CSS 自定义的 counter()

第三种方式就是使用 CSS 的 counter 计算器, 要倒序计数器的顺序,我们有两件事要做:将计数器重置为非 0 的值,并以负数递增计数器。

<ol>
  <li>C</li>
  <li>B</li>
  <li>A</li>
</ol>

CSS 代码:

ol {
  counter-reset: my-custom-counter 4;
  list-style: none;
}

ol li {
  counter-increment: my-custom-counter -1;
}

ol li::before {
  content: counter(my-custom-counter) ". ";
  color: #f23c50;
  font-size: 2.5rem;
  font-weight: bold;
}

效果如下:

CSS 自定义的 counter()

如果我们不知道确切的列表数量,则可以将counter-reset属性移到 HTML 中:

<ol style="counter-reset: my-custom-counter {{ items.length + 1 }}">
  <li>C</li>
  <li>B</li>
  <li>A</li>
</ol>

CSS 代码:

ol {
  list-style: none;
}

ol li {
  counter-increment: my-custom-counter -1;
}

ol li::before {
  content: counter(my-custom-counter) ". "
}

一些文章建议使用 Flexbox 或类似的技术来反转 CSS 中列表顺序。我们不应该这样做,因为它看起来是正确的,但 DOM 的顺序保持不变。在 CSS 中改变顺序对 DOM 顺序没有影响。

<ol>
  <li>A</li>
  <li>B</li>
  <li>C</li>
</ol>

CSS 代码:

ol {
  display: flex;
  flex-direction: column-reverse;
}

效果如下:

HTML 中的 reversed 属性

页面上看好像是我们想要的结果,但你按 F12 打开调试模式,检查该 DOM 的顺序,你会我发现 DOM 的顺序是 “ABC”而不是“CBA”的顺序渲染列表。 另外,如果我们复制并粘贴列表,浏览器可能会以其原始顺序“ABC”复制它。

另外我还在 StackOverflow 上找到的另一个非常有创意的解决方案。其结果与 Flexbox 的解决方案类似,但也有更多的缺点(例如,它会干扰滚动)。

<ol>
  <li>A</li>
  <li>B</li>
  <li>C</li>
</ol>

CSS 代码:

ol {
  transform: rotate(180deg);
}

ol > li {
  transform: rotate(-180deg);
}

当然这估计在绝望中没办法了,才会这么做,我们最好还是不要这样搞。

结语

以上就是今天我为大家分享的不借助后台和 JS ,只用 CSS 让一个列表编号实现倒序效果,如果大家对本篇博客有任何错误和建议,欢迎人才们留言,最后,谢谢大家的观看。

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » 不借助后台和 JS ,只用 CSS 让一个列表编号倒序

发表回复