CSS text-combine-upright 竖行横书组合

这篇文章由 DeathGhost 编辑,发布于

归类于 Css » 👋分享到微博 当前评论 0 条。

我们都知道竖书成行,自右向左换行是古文中的一种书写方式。那么在CSS中writing-mode就定义了文本在水平或垂直方向上排列方式。下面我们通过writing-mode这个属性定义一个“竹简”书写方式,同时如果在竖行文本中穿插阿拉伯数字时又当如何?

我们要定义竹简的书写方式前,首先回顾下 CSS writing-mode 属性,它是定义文本在水平或垂直方向上如何排列。

CSS text-combine-upright 竖行横书组合
CSS text-combine-upright 竖行横书组合

writing-mode语法

writing-mode: horizontal-tb | vertical-rl | vertical-lr | sideways-rl | sideways-lr

由此,我们若要定义出“竹简”的书写模式,就可以运用vertical-rl值,垂直方向由右到左。

示例

先吟诗一首🤭以此为例开始

同在屋檐下,惟有偶遇。

犹如白驹过隙,言之不尽。

因有时不我与,爬耳搔腮,

心之不及也。

—— DeathGhost

div{
  writing-mode: vertical-rl;
}
<div>
  <p>同在屋檐下,</p>
  <p>惟有偶遇。</p>
  <p>犹如白驹过隙,</p>
  <p>言之不尽,</p>
  <p>因有时不我与,</p>
  <p>爬耳搔腮,</p>
  <p>心之不及也。</p>
  <p>—— DeathGhost</p>
</div>
CSS writing-mode 文本排布
CSS writing-mode 文本排布

接下来,我们看看竖行排布中的“意外”。看看下面的图例。

CSS 书写 writing-mode: vertical-rl
CSS 书写模式 writing-mode: vertical-rl (从右到左)

可以看出,若以中文描述还好,但若加入阿拉伯数字,就显得怪异。

那么可否将数字转为横向(常规)书写?

下面我们重点看看CSS中的另一个属性。

text-combine-upright 竖行横书组合

/* Keyword values */
text-combine-upright: none;
text-combine-upright: all;

/* Digits values */
text-combine-upright: digits;
text-combine-upright: digits 4;

/* Global values */
text-combine-upright: inherit;
text-combine-upright: initial;
text-combine-upright: unset;

digits目前浏览器上没有看到效果,这里预先搁置。

我们要将上述文本中的数字让其横向排列,按属性值就是将其水平排列,让其占据单个字符空间。

那么,样式文本定义就可以这样:

div{
  writing-mode: vertical-rl;
  letter-spacing: 1px;
}
div b{
  text-combine-upright: all;
  margin: 5px 0;
}
<div>
  <h1>清朝</h1>
  <p>是中国历史上最后一个封建王朝,</p>
  <p>共传十二帝,</p>
  <p>统治者为满洲爱新觉罗氏。</p>
  <p>从努尔哈赤建立后金起,</p>
  <p>总计<b>296</b>年。</p>
  <p>从皇太极改国号为清起,国祚<b>276</b>年。</p>
  <p>建立全国性政权算起为<b>268</b>年。</p>
</div>

对文本中的<b>标签定义text-combine-uprightall即可。

CSS text-combine-upright 竖行横书组合
CSS text-combine-upright 竖行横书组合

虽然如此,但是,它也是有一定的局限性。

例如,我们将“数字+年”合为一起,或更多文本合为一起,就会看到段尾效果。

CSS text-combine-upright 竖行横书组合
CSS text-combine-upright 竖行横书组合

所以,它占据单个字符空间压缩是有一定限制。

本示例于浏览器chrome87版本,详细可阅读这里


CSS writing-mode upright text-combine-upright 书写方式 数字 横书 竖向文本 横向文本 垂直文本

上一篇:

下一篇: