CSS让文字竖着排列,我们可以使用CSS,在需要竖向显示的地方,强制定义显示区域的宽度,这样字符会自动竖向排列:请看具体代码:
推荐使用这种方法,觉得这个方法兼容性也好,而且代码简洁,字符也容易控制。
1.关于CSS对直排的支持,桑林志中有过探讨,不过其中的资料链接大多已不能打开。简言之:一是使用writing-mode: tb-lr和 layout-flow: vertical-ideographic二是使用column-width和column-gap属性。虽然早在2001年,添加writing-mode支持的草案被提出,但最后并没有成为标准。当年只有微软的Internet Explorer能直接支持竖排方式。2.所以有Geeker去使用JS排出竖排文字的效果,除了Lawrence Li提到的Nehan,另一个叫Taketori JS (竹取 JS)。说到中文排版,在网路上问了一些懂出版的朋友,发现一个很尴尬的事情:日文的断行规则是是 JIS X 4051 日本国家标准;在台湾,规则是各家出版社各个编辑口耳相传的「习惯」。在 Wikipedia 上,排版断行规则的文章也只有日文版、韩文版、英文版就是没有中文版。技术上,业界也不会遇到真正有动机去影响直排实作网路标准的厂商。是说就排版规则这件事情,JIS 标准绝对够用(除了注音符号声符的排版),繁体中文使用者只要站在日文使用者后面增加气势(?)就好,但是我们可以搞到这样,应该有一些需要反省的原因吧。
一、使用writing-mode属性
语法:writing-mode:lr-tb或writing-mode:tb-rl
参数:
1、lr-tb:从左向右,从上往下
2、tb-rl:从上往下,从右向左
运行代码发现,IE显示正常,火狐却不行,所以不建议使用writing-mode属性,下面使用模拟方法实现。
二、模拟文字竖排
代码:
ul{width:100pxheight:80pxoverflow:hiddenlist-style:none}ul li{float:rightdisplay:inlinemargin-left:4pxwidth:14pxheight:100pxfont-size:14pxword-wrap:break-wordword-break:nomal}
此方法让li右浮动,设置li宽度和字宽度一样都是14px,这样就自动换行了。另外,“word-wrap:break-wordword-break:nomal”这句实现标点自动换行(连续字符自动换行)。