小程序-实现竖排文字

时间:2022-04-25
本文章向大家介绍小程序-实现竖排文字,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

最近我在做一个诗词类的小程序:《诗词屋》,已经上线。因为古文有从上到下,从右到左阅读和书写的习惯,所以我设计了一个摘录页面,如下:

整体布局就是按照古代人阅读习惯来的,有点韵味。但是我们如何实现上面那种垂直布局呢?

模板文件如下:

  1. <view class="mod-text">
  2. <text>窗前明月光</text>
  3. <text>疑是地上霜</text>
  4. </view>

那样式该如何写呢?看需求应该和方向或者书写模式有关。也就是CSS中的 writing-mode。

这个属性比较生僻,在一般业务中很少遇到,如果没有见过也不容易想到。它的语法:

  1. /* Keyword values */
  2. writing-mode: horizontal-tb;
  3. writing-mode: vertical-rl;
  4. writing-mode: vertical-lr;
  5. /* Global values */
  6. writing-mode: inherit;
  7. writing-mode: initial;
  8. writing-mode: unset;

初始值是:horizontal-tb。从字面意思我们也应该能猜到什么意思,比如:vertical-rl,就是垂直方向从上到下,水平方向从右到左。

预期表现:

从上图,我们应该能看出,使用 vertical-xx 基本可以实现我们的效果,那我们应该使用哪个呢?

先使用vertical-lr貌似这个接近我们的预期从左向右。那我们该把这个属性放在哪个元素上呢?从它的定义来看,它可以决定子元素的排列方向,那应该放到父元素上即.mod-text

wxss如下:

  1. .mod-text{
  2. writing-mod:vertical-rl;
  3. }

可是效果并不是我们期望的:

如果想不到此时的布局流向,你可以多加一些字:

如果还是别扭,你可以向右歪脖子或旋转图片:

定高是可以实现,但古诗一句的字数是不等的,貌似不够灵活。

仔细想想,我们只要使每一句的古诗占据一列不就行了吗?回忆一下在水平排列时,如何使元素占据一行?就是使元素块级化不就行了。

  1. .mod-text text{
  2. display:block;
  3. }

这就达到了预期的效果:

明天继续说一下另一种解法,如果你有好的方法,可以留言!