CSS中英文字符两端对齐实现
2023-09-11 14:19:56 时间
两端对齐实现
一般加上下面2行就可实现
display: inline-block;
text-align: justify;
但是对于中英文混杂的情况,中英文难一起实现对齐,原因在下面有分析,需要如下js来控制
var ppp = document.getElementById("ppp");
ppp.innerHTML = ppp.innerHTML.split("").join(" ");
justify实现原理
要理解原理,我们首先要搞清楚文本的两端对齐声明text-align:justify
起作用的本质。首先,大家要知道,text-align:justify
是专门为英文设计的,谁叫CSS是老外发明的呢,用来实现英文语句的两端对齐。注意这里的,是语句的对齐。大家应该都知道,英文语句是一个单词一个单词组合而成的,每个单词之前使用空格分隔。text-align:justify
之所以可以让英文段落两端对齐,那是因为每个英文单词之前那个透明看不见的空格被拉伸了。注意,是空格被拉伸了,对,只有空格。因此,当我们写下一段洋洋洒洒中文内容的时候,text-align:justify
是没有任何作用的,跟没设置没任何区别。为什么呢?很简单,因为中文是一个一个汉字,汉字之间是没有空格的,自然也就不能拉伸,自然也就不能两端对齐。
通过代码:ppp.innerHTML = ppp.innerHTML.split("").join(" ");让每个文字之间都有空格字符,于是,text-align:justify
就能大发神威,实现两端对齐。
两端对齐是实现了,但是,空格字符它也是真实存在的字符,是会占据宽度的。如果放任不管,文字就会太稀松,阅读很吃力,会被当bug提出来的,怎么办呢?很简单,我们使用letter-spacing
收缩字符间距就可以了。
ppp.style.letterSpace = '-.15em';
总结:
box.style.textAlign = "justify";
box.style.letterSpacing = '-.15em';
box.innerHTML = box.innerHTML.split("").join(" ");
如果段落含有英文片段,会干掉原来的空格,因为三个空格会被当做一个空格距离处理,因此,我们还需要对连续3个空格左下特殊处理,因此代码进化成:
box.innerHTML = box.innerHTML.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, '').split("").join(" ").replace(/\s{3}/g, " ");
相关文章
- CSS - 解决子级用css float浮动 而父级div没高度不能自适应高度
- 第一百六十六节,jQuery,基础 DOM 和 CSS 操作,元素内容,元素属性,css和class,元素宽度高度、偏移、滚动条
- 【JAVA】java编译错误:编码UTF8/GBK的不可映射字符
- [CSS] Purgecss to remove unused css
- [css]演示:纯CSS实现的右侧底部简洁悬浮效果
- DL之LSTM:基于《wonderland爱丽丝梦游仙境记》小说数据集利用LSTM算法(层加深,基于keras)对单个character字符预测
- 【华为OD机试】1021 - 删除字符串中出现次数最少的字符
- python 将图像变为矢量图(可字符和序列化)
- 习题 8.16 输入一个字符串,内有数字和非数字字符,将其中连续的数字作为一个整数,依次存放到一数组a中。统计共有多少个整数,并输出这些数。
- 练习 2-4 squeeze(s1, s2),将字符串s1 中任何与字符串s2 中字符匹配的字符都删除。
- Leetcode 1624. 两个相同字符之间的最长子字符串(一次过)
- Python编程:Python2和Python3下的translate函数字符映射替换
- 011-Shell 文件中是否包含某字符
- 循环遍历Java字符串字符的规范方法——类似python for ch in string
- 剑指 Offer 48. 最长不含重复字符的子字符串
- 【CSS】表格、定位_普通流定位与浮动定位、其他css常用属性_05