借助wbr标签实现连续英文字符的精准换行

栏目: Html5 · 发布时间: 6年前

内容简介:这篇文章发布于 2018年09月1日,星期六,21:43,归类于HTML相关。 阅读 58 次, 今日 50 次byzhangxinxu from本文可全文转载,但需得到原作者书面许可,同时保留原作者和出处,摘要引流则随意。

这篇文章发布于 2018年09月1日,星期六,21:43,归类于HTML相关。 阅读 58 次, 今日 50 次

byzhangxinxu from https://www.zhangxinxu.com/wordpress/?p=7988

本文可全文转载,但需得到原作者书面许可,同时保留原作者和出处,摘要引流则随意。

借助wbr标签实现连续英文字符的精准换行

一、连续英文换行的问题

在web网页中,连续英文单词默认是不换行的,例如下面的测试代码:

<div style="width:150px; background:#cd0000;">
  CanvasRenderingContext2D.globalCompositeOperation
</div>

实时效果如下(若无效果,可访问原文):

CanvasRenderingContext2D.globalCompositeOperation

可以看到,英文字符直接飞到了 <div> 元素之外(红色背景之外)。

我们通常做法是使用 word-break:break-all 或者 word-wrap:break-word (这两个声明区别可以参见这篇文章)。

例如:

<div style="width:150px; background:#cd0000; word-break:break-all;">
  CanvasRenderingContext2D.globalCompositeOperation
</div>

实时效果如下,可以看到英文单词换行了:

CanvasRenderingContext2D.globalCompositeOperation

但是,会有一个很明显的问题,这换行的位置把英文单词直接破开了,可读性下降明显。

有没有什么方法,技能换行,又不破坏单词呢?

使用 word-wrap:break-word 可不可以呢?在这里是不行的,因为所有字符都是紧密相连,其中没有标准空格,无法区分到底哪个是单词, word-wrap:break-word 就无法大展拳脚,效果就和 word-break:break-all 表现一致:

<div style="width:150px; background:#cd0000; word-wrap:break-word;">
  CanvasRenderingContext2D.globalCompositeOperation
</div>

实时效果如下:

CanvasRenderingContext2D.globalCompositeOperation

借助wbr标签实现连续英文字符的精准换行

此时,CSS不行,HTML可以出马了,HTML中有个 <wbr> 元素标签,可以实现英文单词的精准换行。

二、wbr与英文换行

我们先看效果吧,HTML代码如下:

<div style="width:150px; background:#cd0000;">
  Canvas<wbr>Rendering<wbr>Context2D<wbr>.global<wbr>Composite<wbr>Operation
</div>

也就是把 <wbr> 标签写在单词连接处,于是,神奇的事情发生了:

CanvasRenderingContext2D.globalCompositeOperation

单词分隔的地方,全部都是写入了 <wbr> 标签的地方,这就是 <wbr> 标签的神奇之处,宽度不够,在我这里换行;宽度足够,还是一行显示,非常智能,如下GIF截图效果:

借助wbr标签实现连续英文字符的精准换行

眼见为实,您可以狠狠地点击这里: <wbr> HTML标签功能演示demo

IE浏览器的兼容处理

如果只是单纯写入 <wbr> 标签,在IE浏览器下,至少windows 7系统下,都是无效的,所有字符还是一行显示,Chrome,Firefox等浏览器表现都是符合预期的。

好在有简单的方法使IE浏览器也兼容 <wbr> 特性,就是加个如下CSS片段:

wbr:after { content: '\00200B'; }

U+200B是一个0宽空格,可以看成是和 <wbr> 标签功能对应的字符产物,因此,我们也可以直接在HTML中使用 &#x200b; 代替 <wbr> ,不过语义不太好,建议还是使用 <wbr>

三、wbr与br换行的区别

<wbr> 元素有个近亲叫做 <br> 元素,两者有什么区别呢?

<wbr> 是语句Word Break Opportunity的缩写,表示有机会就断开换行,而 <br> 则直接换行显示,无论宽度足够与否。

四、wbr实际应用

<wbr> 实际应用比较多的,一是技术文档中,例如本文一开始的 CanvasRenderingContext2D.globalCompositeOperation 就是Canvas中的对象和属性名,都比较长,此时需要用到智能换行。

另外一个就是URL地址的处理,这个就不仅仅在技术文档中了,很多对外的大型站点也会用到,尤其在移动端,屏幕宽度小,各种评论信息难免会有URL地址出现,此时,就可以对内容中的URL地址进行匹配,然后在 /. 前面增加 <wbr> 标签即可,写了个简易的替换方法,适用于不含HTML的纯文本信息:

String.prototype.urlWbr = function () {
  return this.replace(/http(?:s)?:\/\/(.*)\//gi, function (matchs, $1) {
    return matchs.replace($1, $1.replace(/(\/|\.)/g, '<wbr>$1'));
  });
};

实地测试下:

<div id="box" style="width:150px; background:#cd0000;"></div>
box.innerHTML = '本文地址是https://<wbr />www<wbr />.zhangxinxu<wbr />.com<wbr />/wordpress<wbr />/2018<wbr />/09<wbr />/html-wbr-word-break/'.urlWbr();

效果如下截图:

借助wbr标签实现连续英文字符的精准换行

您可以狠狠地点击这里: wbr实现URL地址换行demo

五、wbr与部分CSS的关系

如果是非连续英文字符, <wbr> 需要与 white-space:nowrap 配合使用才有意义。

<wbr> 不能与 word-break:break-all 同时使用,也会变得没有意义。

六、结语

在看亚运会男篮决赛,中国与伊朗,现在领先10分了,三分球可以的,形势不错,胜利在望,希望不要毒奶。

其他就没什么好说的了,主要让大家知道还有wbr这样的标签。

感谢阅读,欢迎反馈!

借助wbr标签实现连续英文字符的精准换行

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。

本文地址: https://www.zhangxinxu.com/wordpress/?p=7988

(本篇完)


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创业的艺术2.0

创业的艺术2.0

〔美〕盖伊·川崎 / 刘悦、段歆玥 / 译言·东西文库/电子工业出版社 / 2016-9 / 68

“创业者导师”——盖伊•川崎的《创业的艺术2.0》被阿丽亚娜•赫芬顿评为“终极的创业手册”。无论您是企业家、小企业主、企业开拓者还是非盈利组织的领导人,都可以让你的产品、服务或理念获得成功。 盖伊选取了不用角度,探索前十年商界的巨大变化,并寻求解决之道。曾经所向披靡的市场巨头深陷水深火热之中,社交媒体也取代了人际关系和广告,成为营销推广的主要渠道。众筹也成为广大投资者的可行之举。“云”更是每......一起来看看 《创业的艺术2.0》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

SHA 加密
SHA 加密

SHA 加密工具