androidborder_border-radius在Android下的几个BUG

主要内容来自一丝的border-radius 移动之伤,作了少许的修改和补充;

一、Android 2.3 自带浏览器不支持 %

通常我们实现一个正圆只需要border-radius: 50%即可,大致代码如下:

.foo {

width: 100px;

height: 100px;

border-radius: 50%;

border: 1px solid blue;

}

然而 Android 2.3 是不支持百分比的,要兼容我们只能使用一个较大值,比如border-radius: 999px;

二、Android 及 Safari 低版本 img 圆角问题

当 img 元素有border 时设置border-radius 会导致圆角变形,需要在img 外面嵌套一个元素并设置border 和border-radius。

查看Demo中第2部分

左侧是小米2S(Android 4.1),右侧是红米(Android 4.2)

图一:左侧是小米2S(Android 4.1),右侧是红米(Android 4.2)

三、Android 4.2.x 背景色溢出及不支持 border-radius 缩写

3.1 Android 4.2.x 背景色溢出

测试发现,在 Android 4.2.x 系统自带浏览器中,同时设置border-radius,border和背景色的时候,背景色会溢出到圆角以外部分,可以使用背景剪裁background-clip: padding-box;来修复,但是如果border-color为半透明时,背景直角部分依然会露出来(参见图一)。

关于背景剪裁background-clip

background-clip: border-box|padding-box|content-box;

描述

测试

border-box

背景被裁剪到边框盒。

padding-box

背景被裁剪到内边距框。

content-box

背景被裁剪到内容框。

3.2 Android 4.2.x 不支持border-radius缩写

这个 BUG在小米上测试并未发现,国外有人反映三星 Galaxy S4 中自带浏览器不支持。

解决方案就是使用border-radius的四个扩写属性,缩写属性放到最后。

以上两个问题影响到 Android 4.2.x 内核的系统以及在其基础上定制的系统的自带浏览器,比如:红米,小米3,阿里云OS 等,安卓版 Chrome 不受影响。

完整代码应该是这样的:

.foo {

width: 100px;

height: 100px;

border: 5px solid blue;

border-top-left-radius: 999px; /* 左上角 */

border-top-right-radius: 999px; /* 右上角 */

border-bottom-right-radius: 999px; /* 右下角 */

border-bottom-left-radius: 999px; /* 左下角 */

border-radius: 999px;

background-color: #ccc;

background-clip: padding-box;

}

查看Demo中第1部分

3.3用box-shadow模拟边框

背景色溢出另一个解决办法就是使用box-shadow模拟border;差不多可以达到效果

比如将

border: 1px solid #333333;

替换为:

box-shadow: 0 0 1px 1px #333333;

查看Demo中第3部分

四、其他问题

IE9 中fieldset元素不支持border-radius。

IE9 中带有背景渐变(gradient)的时候背景溢出。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值