作者:Manuel Matuzovic
译者:前端小智
来源:matuzo
有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。
我正在做一个项目,其中有一个倒序的列表。列表创建时间降序排序的,这里我想在语义和视觉上都能体现出来(让列表显示对应的编号,编号越大表示是最新的)。网上做了一些研究,找到了一些有趣的解决办法,有些很好,有些就不那么好了。
最终结果类似如下:
接着,我们来看看有哪些实现的方式。
reversed
属性简单,最直接的解决方案是HTML中的reversed
属性。
<ol reversed>
<li>C</li>
<li>B</li>
<li>A</li>
</ol>
reversed
属性是一个布尔属性,reversed
属性规定列表顺序为降序 (9, 8, 7...),而不是升序 (1, 2, 3...)。
reversed
属性除了 IE 大多数的浏览器都支持,如果你只想要解决方法,用这种就够了。
如果你好奇还有哪些实现方式,请继续阅读。
另一种方法就是使用 value 属性:
<ol>
<li value="3">C</li>
<li value="2">B</li>
<li value="1">A</li>
</ol>
这种方式虽然比较冗长,但我们对列表也有更多控制权,比如,我们还可以这样操作:
<ol>
<li value="6">C</li>
<li value="4">B</li>
<li value="2">A</li>
</ol>
最好还是不要这样做,因为跳过数字可能会让用户感到困惑。
第三种方式就是使用CSS的 counter
计算器, 要倒序计数器的顺序,我们有两件事要做:将计数器重置为非0的值,并以负数递增计数器。
<ol>
<li>C</li>
<li>B</li>
<li>A</li>
</ol>
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中:
<ol style="counter-reset: my-custom-counter {{ items.length + 1 }}">
<li>C</li>
<li>B</li>
<li>A</li>
</ol>
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>
ol {
display: flex;
flex-direction: column-reverse;
}
页面上看好像是我们想要的结果,但你按 F12 打开调试模式,检查该 DOM 的顺序,你会我发现 DOM 的顺序是 “ABC”而不是“CBA”的顺序渲染列表。 另外,如果我们复制并粘贴列表,浏览器可能会以其原始顺序“ABC”
复制它。
另外我还在 StackOverflow 上找到的另一个非常有创意的解决方案。其结果与Flexbox的解决方案类似,但也有更多的缺点(例如,它会干扰滚动)。
<ol>
<li>A</li>
<li>B</li>
<li>C</li>
</ol>
ol {
transform: rotate(180deg);
}
ol > li {
transform: rotate(-180deg);
}
当然这估计在绝望中没办法了,才会这么做,我们最好还是不要这样搞。
本期的分享就到这了,感谢的大家的观看,我们下期分享在见过。
人才们的 【三连】 就是小智不断分享的最大动力,如果本篇博客有任何错误和建议,欢迎人才们留言,最后,谢谢大家的观看。
代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug。
原文:https://dzone.com/articles/ht...
文章每周持续更新,可以微信搜索【大迁世界 】第一时间阅读,回复【福利】有多份前端视频等着你,本文 GitHub https://github.com/qq449245884/xiaozhi 已经收录,欢迎Star。
注释1:上图整个大背景是这个网页的全部尺寸,中间的小框才是浏览器中的可见尺寸...
data URI scheme 允许我们使用内联(inline-code)的方式在网页中包含数据,可以...
简介: 企业上云多账号架构中,如何做到从上到下管理的同时,处理好员工的权限边...
先点赞再看,养成好习惯 前言 这两天在另一个社区看到了一个关于 Tomcat 的提问...
解决方法如下: 第一种 使用iframe,但是目前使用iframe的人已经越来越少了,而...
1.HTML5的内容类型 内容类型 描述 内嵌 向文档中添加其他类型的内容,例如audio...
Redis 官方在 2020 年 5 月正式推出 6.0 版本,提供很多振奋人心的新特性,所以...
John Au-Yeung 来源:medium 译者:前端小智 有梦想,有干货,微信搜索 【大迁世...
复制代码 代码如下: !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional...
content属性一般用于::before、::after伪元素中,用于呈现伪元素的内容。平时con...