ios 加载html图片变形,微信开发里面图片变形的问题

先说原因,ios解释border-radius的百分比值(以50%为例)时,是按当前涉及的边的长度为基准,比如一个400x300的长方形,

它的border-radius就被计算成border-radius: 400*50%/300*50%;

这个属性展开就是

border-top-left-radius: 400*50% 300*50%;

border-top-right-radius: 400*50% 300*50%;

border-bottom-right-radius: 400*50% 300*50%;

border-bottom-left-radius: 400*50% 300*50%;

然后就会变成椭圆,

为啥android看起来不是呢?

因为android对border-radius的解释不一样,安卓是按照短边的长度为基准来计算,上面400x300的长方形的border-radius就会被计算成border-radius: 300*50%/300*50%;

再来说说解决方案,方案很多种,我提供2种

将宽高写死,确保高宽一致,这样不管哪种计算方式都是正方形了。

见下面(如何用css实现一个高宽比固定的盒子),这里涉及一个小的hack

如何用css实现一个高宽比固定的盒子

html 结构

css 样式

.box {

position: relative;

}

.box::before {

content: '';

display: block;

height: 0;

width: 100%;

// padding-bottom的值是关键,你想实现正方形,它的值就要和width的宽度一致

// 因为padding-bottom和padding-top以及margin-top,margin-bottom的百分比

// 值是相对于它们的父元素的宽度的, 这的width用了100%,也就是和父元素等宽了

// padding的百分比的基准其实就和width一致,所以能实现定比.

padding-bottom: 100%;

}

.box .content {

// 保证和.box的高宽一致,.box的高是由::before的高决定的

// 因为absolute的元素不再占据空间。

position: absolute;

top: 0;

left: 0;

width: 100%;

height: 100%;

z-index: 1;

// overflow的值看你的实际情况来决定,但多数时候是需要的。

overflow: auto;

}

你把你的头像的img放到.box盒子里面,应该就能解决了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值