我正在做一个项目,其中有一个倒序的列表。列表创建时间降序排序的,这里我想在语义和视觉上都能体现出来(让列表显示对应的编号,编号越大表示是最新的)。网上做了一些研究,找到了一些有趣的解决办法,有些很好,有些就不那么好了。
最终结果类似如下:
- c
- b
- a
接着,我们来看看有哪些实现的方式。
html中的reversed
属性
简单,最直接的kb88凯时官网登录的解决方案是html中的reversed
属性。
- c
- b
- a
reversed
属性是一个布尔属性,reversed
属性规定列表顺序为降序 (9, 8, 7...),而不是升序 (1, 2, 3...)。
reversed
属性除了 ie 大多数的浏览器都支持,如果你只想要解决方法,用这种就够了。
如果你好奇还有哪些实现方式,请继续阅读。
html中的value属性
另一种方法就是使用 value 属性:
- c
- b
- a
这种方式虽然比较冗长,但我们对列表也有更多控制权,比如,我们还可以这样操作:
- c
- b
- a
最好还是不要这样做,因为跳过数字可能会让用户感到困惑。
css 自定义的 counter()
第三种方式就是使用css的 counter
计算器, 要倒序计数器的顺序,我们有两件事要做:将计数器重置为非0的值,并以负数递增计数器。
- c
- b
- a
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; }
如果我们不知道确切的列表数量,则可以将counter-reset
属性移到html中:
- c
- b
- a
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顺序没有影响。
- a
- b
- c
ol { display: flex; flex-direction: column-reverse; }
页面上看好像是我们想要的结果,但你按 f12 打开调试模式,检查该 dom 的顺序,你会我发现 dom 的顺序是 “abc”而不是“cba”的顺序渲染列表。 另外,如果我们复制并粘贴列表,浏览器可能会以其原始顺序“abc”
复制它。
另外我还在 stackoverflow 上找到的另一个非常有创意的kb88凯时官网登录的解决方案。其结果与flexbox的kb88凯时官网登录的解决方案类似,但也有更多的缺点(例如,它会干扰滚动)。
- a
- b
- c
ol { transform: rotate(180deg); } ol > li { transform: rotate(-180deg); }
当然这估计在绝望中没办法了,才会这么做,我们最好还是不要这样搞。
本期的分享就到这了,感谢的大家的观看,我们下期分享在见过。
人才们的 【三连】 就是小智不断分享的最大动力,如果本篇博客有任何错误和建议,欢迎人才们留言,最后,谢谢大家的观看。
本文转载自:https://segmentfault.com/a/1190000023100092