介绍
我们中的大多数开发人员用来考虑左和右,顶部和底部。这是因为在早期的互联网,它主要用于上传文档,而不是为我们今天知道的复杂的网站结构。 这是原因,没有人认为多语言网站的需求。
概述
旧的盒子模型告诉我们左右上下这四个方向,但在新的模型中,请记住 inline-start inline-end block-start block-end: (LTR)对应关系如下:
- 左: inline-start
- 右: inline-end
- 上: block-start
- 下: block-end
这些适用于 margin padding border 修饰,比如 margin-left 中,left -> 左 -> inline-start -> margin-inline-start 这有点像把坐标系概念引入了布局,对于不同国家,inline 与 block 的方向是不同的:
- 在东亚绝大多数国家、英美系国家 padding-inline-start = padding-left
- 在阿拉伯国家 padding-inline-start = padding-right
- 在日本 padding-inline-start = padding-top
以中国和英美系国家的阅读顺序为基准的话,阿拉伯国家等于把左右颠倒了,而日本是把网页沿顺时针旋转 90 度。
为什么 inline 表示从左右,block 表示上下呢?还记得 display: inline 吗?此时排版是从左到右排布的,而 display: block 的排版是从上到下的。
宽高
width height 也需要换成 inline-size 与 block-size,(LTR)对应关系如下:
- width: inline-size
- min-width: min-inline-size
- max-width: max-inline-size
- height: block-size
- min-height: min-inline-size
- max-height: max-inline-size
See the Pen width height by w3cbest.com (@w3cbest) on CodePen.
下图是 Box Model 与 Logical 的对比:
CSS Positions
之前Positions属性的名称,top/right/left/bottom,先在所有名称都带有前缀inset: inset-block-start / inset-inline-end inset-block-end / inset-inline-start。 (LTR)对应关系如下:
- top = inset-block-start
- bottom = inset-block-end
- left = inset-inline-start
- right = inset-inline-end
尽管这样描述起来很复杂:
.popup {
position: fixed;
inset-block-start: 0; /*top - in English*/
inset-block-end: 0; /*bottom - in English*/
inset-inline-start: 0; /*left - in English*/
inset-inline-end: 0; /*right - in English*/
}
但是这种属性支持聚合写法:
.popup {
position: fixed;
inset: 0 0 0 0; /*top, right, bottom, left - in English*/
}
Float
对于 float 的两个值 left right,可以很容易推测出来,会被 inline-start 与 inline-end 取代,(LTR)对应关系如下:
- float: left = float: inline-start
- float: right = float: inline-end
Text-align
text-align 也有 left right 属性,分别取代为 start end,(LTR)对应关系如下:
- text-align :left = text-align: start
- text-align :right = text-align: end
Css Grid 与 Flexbox
使用 css grid 与 flexbox 布局方案的网页,将在支持的浏览器上自动享受国际化布局调整,不需要改变语法。
Writing-mode
目前为止,看到的是 Css 对排版含义的规范化,Grid 与 Flexbox 由于 API 比较新,定义的较为规范,所以不用变,而旧的 display, position, width, height, float 等 API 需要进行语义化改造。 现在就要聊到最关键的布局国际化部分,我们至今为止遇到的网页都是从上到下的,但其他文化却不同。可以通过配置 writing-mode 让整个网页布局改变:
- writing-mode: horizontal-tb = 从上到下
- writing-mode: vertical-rl = 从右到左 比如日本文化
- writing-mode: vertical-lr = 从左到右 比如蒙古文化
至今还没有见过从下到上的网页,也许这证明了从下到上是最不合理的阅读方式。
Direction
这是一个排版属性,writing-mode 是控制网页方向的,而 direction 是控制文字对齐方向的。 目前只有两个配置:rtl 与 ltr:
html {
direction: rtl;
}
其实 writing-mode 与 direction 结合起来也没什么问题,比如网页布局变成 vertical-rl - 从右到左,那么 direction 的 ltr 就等于是从上到下了。 最后还有一些悬而未决的问题,比如如何开启智能布局?一种方式是:
html {
flow-mode: physical;
/*or*/
flow-mode: logical;
}
另外,像 @meta 配置中的 max-width 也要替换为 max-inline-size, line-height 需要被替换为 line-size,border-width 需要被替换为 border-size 等等。
趋势
整个 Logical Properties 规范看下来是个不可逆的趋势,也代表着 W3C 规范在排版方面的全球化工作。
为什么要改造语法
第一个问题就是这个,我们习以为常的 left top right bottom 语法都需要改成 inline-start block-end 等略微晦涩的语法,而且你可以发现,新语法与旧语法是完全一对一对等的,也就是完全可以交给某个转换程序去做! 可以看出,这是一个习惯问题,W3C 希望重塑国际化布局的语义,而原有的 left top 等无法承担这些语义,所以只好换掉。 新版规范要求开发者做出一个抽象,把自己国家的习惯抽象成习惯无关的描述。但对于每个前端从业者来说,left top 等描述估计已经成为肌肉记忆了,想要改变规范还是挺难的,未来前端社区也许会出现三种解决方案:
- 保守派 - 利用 babel 将原有语法与新语法做一对一映射转换,比如 position: left -> position: inset-inline-start。这种方案 成本最小,且不改变开发者习惯,所以最有可能被国内公司率先采用。在商业环境推动一件事情,最大的阻力无非是 成本 与 共识,这次的布局规范同时触及了这两个点,可能让团队倾向于做保守派。
- 兼容派 - 其实就是两面派,利用 babel 工具做映射这一点与保守派相同,但是新代码推荐用新语法编写,如果团队中有人不遵循新规范,也会被工具自动转换为新规范。这种软要求会导致团队布局代码存在两套,但最终效果却没有问题的神奇效果,长远来说不利于维护,但不失为一种较为妥协的策略。
- 改革派 - 利用脚本,将项目里旧规范替换成新规范,并让团队未来的代码遵循新的布局规范编写。很显然,这派抓住了迁移成本小这个优势,但没有考虑到人这个因素的习惯迁移成本,如何说服其他人理解新规范,并做到让 “未来加入的同事” 也能认同并遵循这套新规范,也许是最大的不确定因素。
为什么 Flex Grid 语法不需改造?
这次改造是冲着 left right width height 等明显带有文化色彩的语法来的。 然而 Flex 语法已经将方向定义转化为抽象的 start 与 end,而 center 是没有歧义的,所以 FlexBox 语法不用改。 而 Grid 是一种拆分单元格的语法,也不涉及具体上下左右的描述,所以也符合国际化语义。