zoukankan      html  css  js  c++  java
  • 中文英文左右padding一致两端对齐实现(转载)

      把大牛的文章拿来,时不时自己看看复习一下,原文地址:http://www.zhangxinxu.com/wordpress/?p=4908

      

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

      

      

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

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

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

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

      

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

      结果就是:

      

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

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

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

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

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

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

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

      

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

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

      补充于翌日:

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

      

    box.innerHTML = box.innerHTML.replace(/^[suFEFFxA0]+|[suFEFFxA0]+$/g, '').split("").join(" ").replace(/s{3}/g, "   ");
    

      

  • 相关阅读:
    剑指offer---二叉搜索树的第k个结点
    剑指offer---把数组排成最小的数
    剑指offer---连续子数组的最大和
    剑指offer---最小的K个数
    Navicat for MySQL(Ubuntu)过期解决方法
    Ubuntu 无法应用原保存的显示器配置
    ubuntu 18.04 install gitlab-ce
    Flask 使用过程
    python版本 3.7.4rc1 (stable) / 3.8.0b1 (pre-release) / 3.9.0a0 (in development)
    Windows10 and MySQL使用
  • 原文地址:https://www.cnblogs.com/peiyuanming/p/4949130.html
Copyright © 2011-2022 走看看