zoukankan      html  css  js  c++  java
  • border-radius 移动之伤

    border-radius我相信对于老一辈的前端们有着特殊的感情,在经历了没有圆角的蛮荒时代,到如今 CSS3 遍地开花,我们还是很幸福的。

    然而即使到了三星大脸流行时代,border-radius在移动端的表现依旧差强人意,主要有以下几点问题:

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

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

    .foo {
         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

    左侧是小米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和背景色的时候,背景色会溢出到圆角以外部分,需要是使用background-clip: padding-box;来修复,但是如果border-color为半透明时,背景直角部分依然会露出来(参见图一)。

    border-radius bug

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

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

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

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

    完整代码应该是这样的:

    .foo {
         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;
    }

    四、其他问题

    1. IE9 中fieldset元素不支持border-radius
    2. IE9 中带有背景渐变(gradient)的时候背景溢出。

    全部 Demo 截图:

    demo

    感谢@方元 同学帮忙测试,欢迎反馈更多移动端 CSS 的问题。

     转载请注明出处:https://github.com/yisibl/blog/issues/2
  • 相关阅读:
    EasyUI datagrid 的多条件查询
    js将时间戳转换为日期类型
    js限制字符串长度,超出的部分补...
    js打印WEB页面内容代码大全
    js倒计时一分钟
    java获取上个星期第一天和最后一天
    两个Html页面之间值得传递
    jS处理中英文时间格式化问题
    JS获取当月第一天和最后一天
    Java 计算两个日期相差月数、天数
  • 原文地址:https://www.cnblogs.com/wpbars/p/6344429.html
Copyright © 2011-2022 走看看