Web前端开发中的反向与倒序

这篇文章发布于 2022年11月6日,星期日,17:27,归类于 CSS相关。 阅读 9097 次, 今日 4 次 8 条评论

 

反向排序

Web中有不少HTML属性或者CSS属性可以实现反向或者倒序的效果,这里整理下,欢迎补充。

一、HTML reversed属性

在HTML中,<ol>元素支持名为reversed的属性,可以在不改变DOM排序的同时,只让前面的序号倒序,例如:

<ol reversed>
  <li>zhang: 这个属性</li>
  <li>xin: IE浏览器</li>
  <li>xu: 并不支持</li>
</ol>

实时渲染效果如下:

  1. zhang: 这个属性
  2. xin: IE浏览器
  3. xu: 并不支持

对于Chrome,Safari等现代浏览器,其兼容性是相当不错的:

列表倒序的兼容性

二、direction与水平倒排

direction属性我之前有详细介绍过,可以参见“CSS direction属性简介与实际应用”一文。

其作用是设置内联元素或者grid布局中的子元素的水平流向。

我们可以基于这个特性让元素水平倒序排列。

前提是这个元素是内联水平的,display计算值是下面中的任意一个都是可以的:inline、inline-block、inline-table、inline-flex、inline-grid。

比方说下面这个例子:

<div class="layout">
  <layout-square>1</layout-square>
  <layout-square>2</layout-square>
  <layout-square>3</layout-square>
</div>
.layout {
  direction:rtl;
  text-align:center;
}
layout-square {
  display: inline-grid;
  width: 100px; height: 100px;
  place-items: center;
  background-color: skyblue;
}

渲染效果如下所示(可以打开控制台查看源码):

1 2 3

direction属性实现水平倒序的优点是兼容性非常的好,不过如今有了flex布局,其应用价值就没那么大了,更多的是用在对称布局或者无法反向排列的grid布局中。

类似的属性还有writing-mode属性,可以实现垂直方向的倒序,有兴趣可以参见这篇经典文章:“改变CSS世界纵横规则的writing-mode属性”。

三、flex-direction与方向控制

要说目前控制元素呈现方向最佳实现非flex布局莫属了。

对应的CSS属性为flex-direction(早期叫做box-direction),可以设置列表元素是水平或垂直方向是否倒序显示(视觉顺序和DOM顺序相反)。

flex-direction: row-reverse;
flex-direction: column-reverse;

大家可以点击下面四个不同的选项,感受下不同的布局效果。

1 2 3

flex-direction属性可以应对80%需要DOM反向呈现的场景。

四、order属性与任意控制

Flex布局中的order属性也是可以设置DOM元素的视觉表现顺序和实际顺序不一样的,其优点在于可以灵活控制每一个独立元素的顺序。

例如某阅读网站,就使用order属性让每一个文字乱序,来增加防盗的门槛。

乱序增加门槛

相比另外一个阅读网站使用绝对定位和transform定位的乱序而言,代码更少,性能更好,开发也更简单。

另外的定位

order属性还支持负值,order:-999,order:-1都是可以的,有时候你希望某元素在最前面,就可以设置 order: -1。

五、Grid布局中的反向排列

Grid由于是二维布局,并不存在反向排序的概念,但是,也不是说不能改变元素的流向,或者显示顺序。

grid-auto-flow属性可以设置Grid布局中的网格是有限水平排列还是优先垂直排列。

语法:

/* 优先水平 */
grid-auto-flow: row;
/* 优先垂直 */
grid-auto-flow: column;

这个我在“CSS grid-auto-flow深入理解”这篇文章中有深入介绍,这里不展开。

位置控制

Grid布局中元素所处位置的控制是通过grid-area属性指定的,值可以是起止网格线,也可以值自定义的名称。

例如:

grid-area: 1 / 2;
/* 将首个网格命名为first-grid */
grid-area: first-grid;

但这种属于单独指定,而不是自动反向排序。

如果希望自动反向,可以使用一开始提到的direction: rtl来实现。

例如MDN文档中的这个示例,加上direction:rtl之后就是从右开始呈现的了。

反向排列

六、float浮动和absolute绝对定位

浮动和绝对定位也可以实现DOM在文档流的后面,但是视觉展示却在前面。

例如本博客列表页的文章配图,虽然在右侧显示,但是DOM的位置却是在左侧,因为这里使用的是右浮动。

浮动与位置示意

绝对定位那更不用说了,left,top等定位可以让元素不受疫情影响,到处飞。

七、动画中的reverse

CSS中的animation-direction属性支持一个名为reverse关键字,可以让动画反向执行。

例如,元素淡入效果这样的:

.element { animation: fadeIn .2s both;}

@keyframes fadeIn {
  0% { opacity: 0; }
  100% { opacity: 1; }
}

想要淡出,无需再重新命名个动画关键帧,使用reverse关键字就可以了。

.element.out { animation: fadeIn .2s reverse both;}

对于 Web animation API也是如此,其支持一个名为reverse()的方法。

有兴趣可以访问“借助Web Animations API实现JS keyframes动画”这篇文章。

八、差不多了,差不多了

也就是一时兴起,想整理下这个专题,以后估计还会出现新奇的玩意,到时候就可以往这里塞,久而久之,本文就是个宝藏资源了。

欢迎补充与反馈。

JS中还有个Array.prototype.reverse()的API方法,可以让数组反序,返回的是原数组(倒序后的原数组),如果希望反序不影响原数组,需要提前复制。

好了,就说这么多吧。

周末写两篇文章的计划算是完成了,还有个小册的提纲要写,事儿好多,B站视频更新,CSS世界修订版,每周一钓,还有写小说,之前一直说文章可以同步到掘金,一直没这个时间和精力,我要想想是不是可以外包出去。

先酱紫吧,感谢大家的阅读!

(本篇完)

分享到:


发表评论(目前8 条评论)

  1. dexterr说道:

    举手提问:在阿拉伯文的情况下,页面内容的排列可以用direction:RTL。各种left right的问题都可以用 inline-start/end解决。

    但是绝对定位的 left,right和背景渐变中的 to right或者xxx deg有没有更好的方法呢?
    现在都是在这些地方单独写一个 [lang=“ar”] xxx{….} 来覆盖,感觉非常笨拙。

    • 张 鑫旭说道:

      有啊,叫做 inset~

      • dexterr说道:

        大受震撼!是我书读少了。。不知道还有inset这玩意。感谢指点!

        在css渐变(conic-gradient,linear-gradient)中的角度有没有什么可以替代原有的left,right,deg,turn?
        按我的理解,既然书写方向变了,那旋转的顺时针应该也变逆时针的。可是 45deg和0.25turn的表现不管怎样都是顺时针。

  2. totodo说道:

    和这篇文章无关.
    起点阅读页面出现的那个红包在平板(苹果 9.8 的)横屏状态下, 高度是超出屏幕无法关闭的, 希望能调一下.

  3. 代码如诗如画说道:

    文章同步到掘金,我可以胜任!

  4. liuliu说道:

    您研究得太深了,每次都有收获,感谢分享知识