html字体向下对齐,css实现不同浏览器下兼容文本两端对齐

本文探讨了如何在前端表单中优雅地实现文本框提示文本的两端对齐,包括CSS尝试、纯CSS与DOM结合的解决方案,以及针对不同浏览器的兼容性处理。作者分享了多个实现方法及其优缺点,并给出了最终兼容各浏览器的代码实例。

在 form 表单的前端布局中,我们经常需要将文本框的提示文本两端对齐,例如:

02a3222fc07c29a0c74522919d53a1dd.png

比较粗暴的做法是在需要隔离边距的文本中加标签,然后分别控制每个文字的边距,这种方法比直接加空格或者占位符更精准,我之前也都是这么做的。但是写的多了之后开始思考能不能抽象出来用于更多的场景?让代码更好看一些?维护成本更低一些?

1、首先想到是能不能直接靠 css 解决问题

css

.test-justify {

text-align: justify;

}

html

测试文本

6276f5e28f99ab85104b73e8372cf024.png

好吧,text-align:justify 完全无效,不甘心,于是用一段文本测试了下,效果如下:

b8fc4bac9e7f88fa7ca7181bdc24015a.png

原来这个属性是针对段落文本两端对齐的,接着试一下 text-align-last: justify 这个属性

css

.test-justify {

text-align: justify;

}

a9e078f8c391999ade28fef3b9dccedf.png

效果是达到了,但缺点是完全不兼容 ie 和 safari 浏览器。

2、接着思考,既然上述实现存在兼容性问题,那么能不能为 2 个,3 个,4 个等这样长度的文本单独写 css 类解决,因为表单的文本框提示文字也不会很多。

css

div {

width: 100px;

}

.w2 {

letter-spacing: 2em;

}

.w3 {

letter-spacing: 0.5em;

}

html

测试
测试了
测试来了

71792883db0f56081f5b317a534d3e03.png

这种方案看起来能够解决问题,应对大部分场景应该没问题了,但遗憾的是并不是真正的两端对齐,特殊显示的情况下还是无法满足需求,我们先放着,继续往下尝试。

2、以上是纯 css 实现方式,接下来我们看看 css 和 dom 结合能不能做出统一形式的解决方案。

html

测 试 文 本

css

.test-justify {

text-align: justify;

}

span {

display:inline-block;

padding-left:100%;

}

c7af643f9c7a0ffb2b65b06330a16bc1.png

想想还有一些小激动呢,而且完美兼容 ie 和 safari,这种方案其实就是第一种段落对齐方案的扩展,用空格强制分词,然后用 span 伪造最后一行(test-justify 不会对最后一行进行对齐)。

为了增加扩展性,我们还得对这种方案进行优化,因为大多数情况下文本是后端加载的。

例如 .net core razor 视图加载 model displayname 的写法

只要加一小段js然后就应该能兼容所有场景了。

css

div {

width: 300px;

border: 1px solid #000;

}

.test-justify {

text-align: justify;

}

span {

display:inline-block;

padding-left:100%;

}

html

测试文本

js

var $this = $(".test-justify")

, justifyText = $this.text().trim()

, afterText = "";

for (var i = 0; i < justifyText.length; i++) {

afterText += justifyText[i] + " ";

}

afterText = afterText.trim() + "";

$this.html(afterText).css({ "height": $this.height() / 2 + "px" });

720ab13e9649ae4f2dfa0c1e9775f4a5.png

好了,这种方案应该能支持主流的浏览器了,但缺点是由于通过js再调整的,所以刷新的时候仔细看会看到文本两端对齐的过程(闪一下),体验并不是很好,那就做一下兼容吧。

只有 IE 和 Safari 不支持 text-align-last: justify 所以只考虑这两种浏览器的情况下调用最后一种方案

function myBrowser() {

var userAgent = navigator.userAgent;

//判断浏览器版本

var isOpera = userAgent.indexOf("Opera") > -1;

var isIE = userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1 && !isOpera;

var isEdge = userAgent.toLowerCase().indexOf("edge") > -1 && !isIE;

var isIE11 = (userAgent.toLowerCase().indexOf("trident") > -1 && userAgent.indexOf("rv") > -1);

if (/[Ff]irefox(\/\d+\.\d+)/.test(userAgent)) {

return "Firefox";

} else if (isIE) {

return "IE";

} else if (isEdge) {

return "IE";

} else if (isIE11) {

return "IE";

} else if (/[Cc]hrome\/\d+/.test(userAgent)) {

return "Chrome";

} else if (/[Vv]ersion\/\d+\.\d+\.\d+(\.\d)* *[Ss]afari/.test(userAgent)) {

return "Safari"

} else {

return "unknown"

}

}

var browser = myBrowser();

if (browser == "IE" || browser == "Safari") {

var $this = $(".test-justify")

, justifyText = $this.text().trim()

, afterText = "";

for (var i = 0; i < justifyText.length; i++) {

afterText += justifyText[i] + " ";

}

afterText = afterText.trim() + "";

$this.html(afterText).css({ "height": $this.height() / 2 + "px" })

}

哈哈哈,完美!

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值