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盒子里面,应该就能解决了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信开发小程序模拟器中图片无法显示的问题可能有多种原因。根据引用内容,有以下几个可能的原因和解决方案: 1. 在安卓设备上,拼接的路径返回的是一个流,需要将其转换成base64格式才能正常显示。而在PC和iOS设备上可能内部已经做了处理,所以可以显示出来。因此,你可以尝试在安卓设备上对返回的流进行处理,将其转换成base64格式后再进行显示。\[1\] 2. 如果你在本地服务器上使用了localhost作为路径,而在手机上无法显示图片,可能是因为手机无法访问本地服务器。你可以将localhost替换为你的本机IP地址,确保手机和电脑连接在同一个WiFi网络下,这样手机才能访问到本地服务器上的图片。\[2\] 3. 另外,如果你在微信开发者工具中使用了英特尔显卡,可能遇到图片无法显示的问题。你可以尝试打开英特尔显卡控制面板,依次进入显示器设置,将量化范围设置为全范围,然后保存应用。这样可能可以解决图片显示问题。\[3\] 综上所述,你可以尝试根据以上的解决方案来解决微信开发小程序模拟器中图片无法显示的问题。 #### 引用[.reference_title] - *1* [微信小程序 图片显示不出来的问题 100%管用](https://blog.csdn.net/qq_61033782/article/details/125779838)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [微信小程序在模拟器可以显示,手机扫编译二维码显示不了 解决办法](https://blog.csdn.net/m0_51094219/article/details/129773134)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [微信小程序开发工具模拟器不显示鼠标问题【推荐两方案】](https://blog.csdn.net/sdfjasad/article/details/124019401)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值