使用writing-mode让文字竖向排版

本文介绍了如何使用CSS3的writing-mode属性实现文字的竖向排版,包括从上到下及从右到左的不同排版方式。同时提供了兼容性的解决方案,并展示了实际应用案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


通常我们网页上的文字在缺省状况下是从左到右横向排版的,但有些情况下,为了排版效果,或为了更好的利用页面空间,我们需要将文字竖向排版。以前有一种很土的方法,就是让文字的容器只有一个文字的宽度,挤的文字竖向排列。在table表头里通常会有这种效果。

writing-mode是CSS3里新引入的可以让文字竖向排版的属性。它不仅可以让文字竖向,还可以让文字从右往左排。这个CSS3属性还处在实验阶段,使用最新版的谷歌浏览器或火狐浏览器时,最好在属性前面加入浏览器引擎前缀

下面我们看看writing-mode属性的语法:

/* Keyword values */
writing-mode: horizontal-tb;
writing-mode: vertical-rl;
writing-mode: vertical-lr;

/* Global values */
writing-mode: inherit;
writing-mode: initial;
writing-mode: unset;

writing-mode的几个属性值介绍:

horizontal-tb

文字从左到右排列,换行内容是从上往下扩展。
vertical-rl
文字从上到下排列,换行内容是从右往左扩展。
vertical-lr
文字从上到下排列,换行内容从左往右扩展。
sideways-rl
是正常的文字内容逆时针旋转90度得到的效果。
sideways-lr
是正常的文本内容顺时针旋转90度得到的效果。

下图是设计预期的效果图:

实际执行效果是这样的:

上面sideways-rlsideways-lr两个属性目前还处于试验阶段,有些浏览器里不一定有效果。对于这种效果的文字排版,我们有很好的替代方法,就是使用CSS3里的变换旋转功能:

.vertical-text {
	transform: rotate(90deg);
	transform-origin: left top 0;
}

实例效果:

writing-mode废弃的属性值

注意:下面这些属性是已经废除的writing-mode属性值,如果你在新版浏览器里属于这些属性值将没有效果。

  1. lr-tb
  2. tb-rl
  3. lr
  4. rl
  5. tb
原文: http://www.lindukj.cn/news/archives/823
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值