android webview css样式不支持,解决低版本安卓系统中webview对css的background写法不兼容问题...

在对接第三方App时,发现内嵌的WebView页面在低版本Android系统中,一个div容器的背景图和背景颜色无法正常显示。经过排查,问题出在CSS的背景属性简写形式不被支持。将简写形式改为完整属性形式后,问题得到解决。这可能是低版本Android系统内嵌浏览器对CSS简写的支持不足,而微信内置浏览器可能已对此进行优化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

对接第三方app的时候发现内嵌网页里面的背景图死活出不来,但是在同一个手机上的微信自带浏览器确是正常的,通过各种尝试终于发现问题,记录一下。

对方使用的方式是app里面内嵌一个webview加载我方的手机端页面,这个页面在大部分流行的安卓机器上都使用正常,没有出现过大的样式偏差,但是一放进app里面样式就出现了问题。具体表现是一个div容器的背景图出现不了,背景颜色也没有了。

分析

首先把原来的代码贴出来

background: #e3e3e3 url("../img/loading.gif") no-repeat center center / 70px auto;

display: block;

position: fixed;

top: 0;

left: 0;

z-index: 50001;

width: 100%;

height: 100%;

通过排除法首先去掉这个div容器position的fixed,因为fixed出现过很多不兼容问题,我首先想到的就是这个问题,直接删掉position这个样式,测试发现问题依旧。

我开始怀疑是网络加载慢导致的背景图加载不出来。直接去掉背景图,背景颜色居然神奇的出现了,代码变成了这样

background: #e3e3e3;

display: block;

position: fixed;

top: 0;

eft: 0;

z-index: 50001;

width: 100%;

height: 100%;

真是诡异,正常情况下不应该,难道是因为缩写导致的?

怀着无比怀疑的心态把上面那段简写全部拆写成完整版,代码如下

background-color: #e3e3e3;

background-image: url('../img/loading.gif');

background-repeat: no-repeat;

background-position: center center;

background-size: 70px auto;

display: block;

position: absolute;

top: 0;left: 0;

z-index: 50001;

width: 100%;

height: 100%;

测试发现问题居然神奇的解决了。

总结

推测是低版本安卓系统里面调用系统自带浏览器作为webview的时候对css的一些简写写法不支持,导致无法正常渲染,新版本安卓系统已经修复这个问题,之所以微信中没有出现bug大概是因为微信内置的是自家的QQ浏览器内核,优化过这个问题。

本文链接:https://www.92ez.com/?action=show&id=23451

!!! 转载请先联系non3gov@gmail.com授权并在显著位置注明作者和原文链接 !!! 小黑屋

提示:技术文章有一定的时效性,请先确认是否适用你当前的系统环境。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值