小技巧|CSS如何实现文字两端对齐

需求如下,红框所在的文字有四个字的、三个字的、两个字的,如果不两端对齐可以选择居中对齐,或者右对齐。但是如果要像下面这样两端对齐呢?

我相信以前很多人都这么干过:两个字中间使用 来隔开达到四个字的宽度,三个字也可以,但是,像上图中“122账号”“122密码”这样的,就不好计算该用几个空格了。

假如我们有如下HTML:

 
    
1
 
    
<div>这世间唯有梦想和好姑娘不可辜负! </div>

给它加点样式

 
    
1
2
3
4
5
 
    
div{
width: 500px;
border: 1px solid red;
text-align: justify;
}

初始效果是这样的

text-align: justify这是什么东西?CSS2中text-align有一个属性值为justify,为对齐之意。其实现的效果就是可以让一行文字两端对齐显示(文字内容要超过一行)。

但是光使用它依然没什么卵用…..

要使文字两端对齐,我们还得使用一个行内空标签来助阵,比如<span><i>等等,这里是我用<i>标签

 
    
1
 
    
<div>这世间唯有梦想和好姑娘不可辜负! <i> </i> </div>

给这个i标签设置如下样式

 
    
1
2
3
4
5
 
    
div i{
display:inline-block;
/*padding-left: 100%;*/
width: 100%;
}

padding-left: 100%width:100%都可以达到效果,选用其一即可。效果如下

但是加入HTML元素又违反了结构表现分离的原则,我们可以改用after、before伪元素:

 
    
1
2
3
4
5
 
    
div :after {
content: " ";
display: inline-block;
width: 100%;
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值