css日常积累

1.text-align:justify;不起作用是怎么回事?
转载自: https://segmentfault.com/q/1010000007136263

为什么单独设置text-align:justify;不起作用,非要在后面加一个内联块状元素宽度为100%的才可以?

<p class="center">我是两端对齐文字端对齐文字<span></span></p>

css样式

.center{
  text-align:justify;
}

span{
  display:inline-block;
  width:100%;
}

原因是:

这个是因为text-align不会处理被打断的行和最后一行。因为你这里的文字只占了一行,所以也是最后一行了,所以text-align设置为justify不会产生任何效果。
解决方法是使用text-align-last,并将其设置为justify。
不过不幸的是,text-align-last不是所有浏览器支持。
(2020年的支持也不是太好 https://caniuse.com/#search=text-align-last)
所以对于不支持text-align-last的,可以在最后一行人工生成两行文本,然后把第二行隐藏了,那么我们要现实的第一行自然就可以实现两端对齐了。
而你的span是inline-block,也可以设置宽度(100%),那么这个时候内联匿名盒的宽度超过行盒,浏览器会将其拆成两行,自然第一行文本的text-align效果就生效了。你的实现刚刚好是上面的第二个实现方法。

也有另外一种css写法:

span:after {
      content:'';
      width: 100%;
      display: inline-block;
      overflow: hidden;
      height: 0;
    }

虽然以上2种写法都实现了单行文字的两端对齐。
在这里插入图片描述
由于多设置了一行空的span,那么处理的折衷方法就是为.center设置一个合适固定的高度并且overflow:hidden来移除空行的span

2.为适配不同终端机型的屏幕宽度和像素密度,我们一般会使用如下方法设置图片的CSS样式:

<style>
    img{
        max-width:100%;//意思是不超出父元素的宽度,但是最大的宽度不会超过自身宽度。就是图片只能缩小,不能放大
        height:auto;
    }
</style>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值