好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-小tip:中文英文左右padding一致两端对齐实现

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

补充于2017-04-09
目前Firefox和Chrome纯中文(即使没有空格)也是可以自动两端对齐的,因此本文后面的内容实际上可以由下面的 CSS 代码组合实现!

.justify {     text-justify: inter -i deograph;     text-align: justify; }

无需使用麻烦的JS去处理。
// 补充end& # 8230;

不 是什么 稀奇的技 术 ,很多很多年前自己就玩耍过。

之所以今天拿出来说一下,是因为今天几个小伙伴遇到类似问题,突然发现,一些自己 觉得 不怎么样的东西,说不定对 别人 而言会有很大帮助,于是我就打算写篇短文 简单 介绍下,希望可以帮助到有需要的小伙伴。

是个什么东西呢?

先看下图:

就是一个定 宽 的容器,左右padding值20像素,结果输入一段文字后(有中文也有英文字符),会发现右侧根本就不对齐,有些地方 距离 右侧的空白大小也不是20像素,感觉不和谐,设计师就希望排列能够好看 一点 , 右边 要对齐。

其实呢,要实现两端对齐很简单,使用 text-align:justify , 之前有写过“dis play :inline-block/text-align:justify下列表的两端对齐布局”,也是属于 text-align:justify 的精彩应用;然后配合其他一些小技巧,就能实现任意中英文的两端对齐排列效果了。

您可以狠狠地点击这里:中文或英文两端对齐Demo

我们可以看到,demo页面上有一段朴实的文字:

然后我们点击按钮变身一下,会发现,文字内容乖乖两端对齐了:

这种对齐效果,IE6/IE7浏览器也是支持良好的,例如,下面这个IE7下的截图:

实现原理
要理解原理,我们首先要搞清楚文本的两端对齐声明 text-align:justify 起作用的本质。首先,大家要 知道 , text-align:justify 是专门为英文设计的,谁叫CSS是老外发明的呢,用来实现英文语句的两端对齐。注意这里的,是语句的对齐。大家 应该 都知道,英文语句是一个单词一个单词组合而成的,每个单词之前使用空格分隔。

text-align:justify 之所以可以让英文段落两端对齐,那是因为每个英文单词之前那个透明看不见的空格被拉伸了。注意,是空格被拉伸了,对,只有空格。因此,当我们写下一段洋洋洒洒中文内容的时候, text-align:justify 是没有任何作用的,跟没设置没任何区别。为什么呢?很简单,因为中文是一个一个汉字,汉字之间是没有空格的,自然也就不能拉伸,自然也就不能两端对齐。

怎么办呢?难道中文就不行了吗?

当然不是!既然 正常 的中文文字之间没有空格,我们自己加一点不就好了。例如下面代码:

"宁泽涛小鲜肉".spl IT ("").join(" ");

结果就是:

会发现,每个中文文字之间都有的空格字符,于是, text-align:justify 就能大发神威,实现两端对齐!

OK,现在两端对齐是实现了,但是,空格字符它也是真实存在的字符,是会占据宽度的。如果放任不管,文字就会太稀松,阅读很 吃 力,会被当bug提出来的,怎么办呢?

很简单,我们使用 let ter -s pacing 收缩字符间距就可以了。例如demo页面:

box.style.letterSpacing = '-.15em';

不同字体的 letter-spacing 负值不一样,使用 em 单位呢,可以更智能适配各个 font-size 的文字。demo使用的 微软雅黑 字体,我大致测试了下, -.15em 是个挺合适的值,其他字体我就不详了,你有兴趣,可以自己捣腾下。

至此,我们的任意中文英文的两端对齐效果就实现了。

使用JS再总结下就是(假设 box 是文字容器元素):

ox.style.textAlign = "justify"; box.style.letterSpacing = '-.15em'; box.innerHT ML  = box.innerHTML.split("").join(" ");

寥寥3行代码,我们就大功告成了!

补充于翌日:
上面的方法适用于中文内容,如果段落含有英文片段,会干掉 原来 的空格,因为三个空格会被当做一个空格距离处理,因此,我们还需要对连续3个空格左下特殊处理,因此代码进化成:

box.innerHTML = box.innerHTML.replace(/^[/s/uFEFF/xA0]+|[/s/uFEFF/xA0]+$/g, '').split("").join(" ").replace(//s{3}/g, " & am p;nbsp; ");

(本篇完)

觉得可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-小tip:中文英文左右padding一致两端对齐实现 全部内容,希望文章能够帮你解决 html5教程-小tip:中文英文左右padding一致两端对齐实现 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-小tip:中文英文左右padding一致两端对齐实现的详细内容...

  阅读:35次