CSS创建竖排文字的简单方法

  在制作网页的时候我们经常需要创建一些竖排的文字,或许这对你来说是一件很简单的事情,但是你是否想过用CSS可有N种创建竖排文字的方法?下面是由我翻译自Nettuts+的文章,希望这几种方法能够给你带来一些提示。

  方法一:<br />标签

  一种可能的方法(但不推荐)是在每个字母后面添加<br />标签来实现竖排文字:

<h1>
   N <br />E <br />T <br />T <br />U <br />T <br />S
</h1>

  点击查看演示

  千万不要使用使用这种方法,它是跛脚和草率的。

  方法二:静态包裹

  通过这个方法,我们将每个字母包裹在一个span中,然后在CSS中设置它的display属性为block

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>Vertical Text</title>

<style>
  h1 span { display: block; }
</style>
</head>
<body>

  <h1>
   <span> N </span>
   <span> E </span>
   <span> T </span>
   <span> T </span>
   <span> U </span>
   <span> T </span>
   <span> S </span>
  </h1>

</body>
</html>

  点击查看演示

  这种方法的问题是,除了可怕的标签外,它需要你手工去给每个字母用span括起来。如果这些文字是由CMS动态生成的,那就别用这种方法了。

  方法三:使用JavaScript

  我最初的想法是用JavaScript动态地添加span标签,这样我们就避开了方法二遇到的问题。

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>Vertical Text</title>

<style>
  h1 span { display: block; }
</style>
</head>
<body>
  <h1> NETTUTS </h1>

  <script>
    var h1 = document.getElementsByTagName('h1')[0];
    h1.innerHTML = '<span>' + h1.innerHTML.split('').join('</span><span>') + '</span>';
  </script>
</body>
</html>

  点击查看演示

  这个方法绝对是一个进步。以上方法中,我们将一行文本(NETTUTS)分拆放到一个数组中,并且将每个字母用span标签括起来。虽然我们可以用如for语句或$.map来筛选这个数组,但是更好更快的方法是手动地同时将文字插入和括起来。虽然相比方法二,这种方法更好,但是仍然不推荐此方法:

  在JavaScript被禁用的情况下会破坏你的布局

  理想的情况下,如果可能的话,我们应该使用CSS来完成这个任务。

  方法四:给容器指定一个宽度

  如果可能的话,还是让我们远离JavaScript吧。如果我们给容器元素指定一个宽度,并强迫文字换行,如何?那是可以的。

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>Vertical Text</title>

<style>
  h1 {
    width: 50px;
    font-size: 50px;
    word-wrap: break-word;
  }
</style>
</head>
<body>
  <h1> NETTUTS </h1>
</body>
</html>

  点击查看演示

  在这个方法中,我们给h1定义很窄的宽度,然后是其文字的宽度等于外围的宽度,最后设置word-wrap 等于 break-word,这样我们就可以强制每个字母单独在一行。不过需要注意的是, break-word是一个CSS3的属性,并不是所有浏览器都兼容。如果排除旧浏览器的话,这个问题貌似就可以解决了。。。但并完全是!上面的演示确实可以正常工作,但是玩像素值是很危险的,不信可以看看 将大写字母转换成小写字母的后果(在IE下看看):

  所以,使用这种方法,当你给h1指定具体像素宽度的时候,要特别小心。这种方法也不推荐!

  方法五:使用 letter-spacing

  作为预防措施,并扩展方法四,我们为什么不申请相当大的letter-spacing来解决这个问题?

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>Vertical Text</title>

<style>
  h1 {
    width: 50px;
    font-size: 50px;
    word-wrap: break-word;
    letter-spacing: 20px; /* Set large letter-spacing as precaution */
  }
</style>
</head>
<body>
  <h1> Nettuts </h1>
</body>
</html>

  点击查看演示

  这似乎解决了这个问题,但是在这里,我们又使用了一些CSS3的属性。

  方法六:使用 ems

  另外,还有一个一行内的解决方法。不知道你有没有记得,当给父级元素指定 overflow: hidden 的时候,父元素就会扩展以包含浮动? 这个方法就类似这个,关键是使用了 em,并给每个字母之间添加了空格。

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8 />
<title>Vertical Text</title>

<style>
  h1 {
    width: 1em;
    font-size: 40px;
    letter-spacing: 40px; /* arbitrarily large letter-spacing for safety */
  }
</style>
</head>
<body>
  <h1> N e t t u t s </h1>
</body>
</html>

  点击查看演示

  漂亮又整洁,对不对?并且,这种方法可以给你的文字指定任意的font-size,因为我们使用了em,它就相当于选择字体的x-height,给我们提供了更多的灵活性。

  但是,你是否又一次想起,有时一行中会有不止一个字母。可实际情况是,你可以安全使用这种方法,因为我已经指定了一个相当大的letter-spacing,以确保一行只会有一个字母。

  到目前为止,据我所知,这是最好的跨浏览器兼容的解决方案。

  方法七:Whitespace

  最后一个方法来达到这种效果是使用 white-space属性。

<!DOCTYPE HTML>
<html lang="en">
   <head>
      <meta charset="UTF-8">
      <title>Vertical Text</title>
      <style>
         h1 { white-space: pre; }
      </style>
   </head>
   <body>

      <h1>
         J
         E
         F
         F
         R
         E
         Y
      </h1>
   </body>
</html>

  点击查看演示

  通过设置 white-space 的值为 pre,即可控制文字的排版就像在一个 pre 标签中一样。因此,它会严格地显示你添加的空格。

原文出处:露兜即刻 https://www.ludou.org/the-easiest-way-to-create-vertical-text-with-css.html

本站原创内容,如需转载请注明来源:https://www.liutonghui.com/28.html

上一篇 2013-10-21
下一篇 2013-12-14

评论列表(0条)

  • 暂时没有评论!

发表评论

captcha

相关推荐

  • JavaScript正则表达式验证身份证号码是否合法

      正则表达式(regular expression)是一个描述字符模式的对象。下面通过本篇文章给大家介绍js正则表达式验证身份证号码是否合法,需要的朋友可以参考下本篇文章   第一种方法:   在用户注册页面有些需求要求的比较严格,需要对身份证js验证是否合法,通过此功能严格此系统软件,从而过滤到很多水客。下面就此实现方法给大家讲解下。   很多时候我们都是通过一组正则表达式来判断用户输入的身份证是否合法,那在用正则表达式判断之前,你......

    2015-09-05
    16660
  • 王杰出道35周年出新歌,60岁浪子仍洒脱

      12月17日,消失在歌迷视线中多年的老牌创作型歌手王杰突然发布了一首新歌《一场游戏一场梦(结束篇)》,今年是2022年,正好是王杰出道35年整。1987年12月19日,王杰在台湾发行首张专辑《一场游戏一场梦》正式出道,这张专辑一经发行就轰动了整个华语乐坛,在中国台湾、中国香港、中国大陆、东南亚等地都创下了惊人的销量,专辑中的同名主打歌《一场游戏一场梦》、《安妮》等歌曲直到今天依然是KTV点唱率非常高的歌曲。 点击上方播放视......

    2022-12-24
    8160
  • 远离谎话连篇三观不正的人

      人一辈子很短,应该活得光明磊落,问心无愧,才能对得起自己,让人生有价值有意义。做个坦坦荡荡堂堂正正的人是一辈子,做个谎话连篇自欺欺人的嘴炮也是一辈子。可偏偏就有这种人,不去付出行动创造幸福,反而把时间和精力都用在弄虚作假上,整天吹牛逼编故事表演给人看,三吹六哨,撒谎成性。一张破嘴吹天吹地撒谎尿屁的信口开河,嘴里没一句真话。天天活在谎言里,连一个真实的自己都不敢做,虚伪做作,三观不正。一边抱怨又一边虚度时光,诋毁别人的成就和拥有,把责......

    2023-01-19
    8564
  • 解决 PHP 8.1 隐式类型转换导致缩略图生成错误

      这几天解决了一个困扰已久的问题,我的博客系统在文章上传图片生成缩略图时,在本地测试环境没有任何问题,但在服务器环境中总是生成缩略图失败,报错:"Implicit conversion from float"。排查了 PHP 和环境扩展组件库、目录权限、图片格式大小等都没有问题。在百思不得其解时,我注意到了一个平时不太注意的细节,我在本地测试环境用的是 PHP 8.0,服务器上用的是 PHP 8.1,经过反复测试问题果然出在这里。  ......

    2023-09-04
    7150
  • 吴咏宁:极限运动梦想中的坠亡

      近日,中国的一位极限运动爱好者吴咏宁的坠亡事件引起了广泛关注。他以其高空挑战和极限运动视频在短视频平台上获得了巨大的关注,成为了一名网红。然而,在他拍摄最新一次极限运动视频时,意外发生了。据报道,他在进行一次高空挑战时失手坠落,不幸身亡。这个消息让所有关注他的人震惊不已,不敢相信这样一个年轻有为的生命就这样消逝。   吴咏宁是一位以高空挑战和短视频为主的极限运动员,通过社交媒体平台吸引大量粉丝。然而,他的极限表演背后却隐藏着巨大的......

    2017-12-05
    11160
  • 华为Mate60手机开售,麒麟5G芯片回归,遥遥领先!

      没开发布会,没有预告就直接开卖备受关注的旗舰手机,华为Mate60系列算是开了个头。这几天华为登上了热搜,这次是因为华为Mate60手机携带&ldquo;麒麟芯片&rdquo;提前开售,瞬间售罄,同时也标志着麒麟5G芯片的正式回归。这一消息在各大主流媒体平台上迅速引发热议,网友们纷纷发表意见,自媒体人也争相蹭热度,提出各自观点。   如果你打开华为商城app,可以看到华为已经在自家商城上架了华为Mate60系列手机,而这些手机已经......

    2023-08-31
    7270
  • HTML中CSS和JS链接中的版本号

      在搜索引擎中搜索关键字.htaccess 缓存,你可以搜索到很多关于设置网站文件缓存的教程,通过设置可以将css、js等不太经常更新的文件缓存在浏览器端,这样访客每次访问你的网站的时候,浏览器就可以从浏览器的缓存中获取css、js等,而不必从你的服务器读取,这样在一定程度上加快了网站的打开速度,又可以节约一下你的服务器流量。   现在问题来了,.htaccess设置的css、js缓存都有一个过期时间,如果在访客的浏览器中已经缓存了......

    2013-10-10
    19340
  • HTML5新手入门指南

      HTML5是HTML的最新版本,引入了一系列新的元素、属性和API,使得开发者可以创建更强大、更交互性的Web页面。以下是HTML5新手入门指南的一些建议:   1. 基础结构 &lt;!DOCTYPE html&gt; &lt;html lang="en"&gt; &lt;head&gt; &lt;meta charset="UTF-8"&gt; &lt;meta name="viewport" content="......

    2015-02-18
    18340