zoukankan      html  css  js  c++  java
  • css3字体缩放样式-webkit-text-size-adjust的用法详解

    写页面的应该都知道Chrome浏览器默认情况下的字体最小为12px,如果你要设置某字体大小为10px的话,你会在Chrome发现还是12px。如果要使此生效的话,就得修改Chrome的默认配置了,一般应用下面的代码就能在全局生效了:

    html { -webkit-text-size-adjust: none; }

    但是这样设置之后会有一个问题,就是当你放大网页时,一般情况下字体也会随着变大,而设置了以上代码后,字体只会显示你当前设置的字体大小,不会随着网页放大而变大了,这样对有需要放大网页观看的用户造成了不好的用户体验,所以不建议全局应用该属性,而是在需要的情况单独使用就好了。

    在中文版Chrome里面,网页CSS里所有小于12px的字体设置都无效,最终将显示12px。这样弄的本意可能是好的,因为中文一旦小于12px,就变得不易阅读。

    但中文版Chrome也会阅读英文网站啊,中文网页里面也会有英文的小字体设置需求啊,尤其是一些文字部份的设计,不小实在不好看,影响整个排版的美观。

    解决方案,添加一个私有属性到html选择器::

    html{-webkit-text-size-adjust: none;}

    顾名思义, 禁用Webkit内核浏览器的文字大小调整功能。

    如果要打开缩放功能,则定义下面的全局样式:

    *{-webkit-text-size-adjust:auto !important;}

    故-webkit-text-size-adjust的用法如下:

    1、当样式表里font-size<12px时,中文版chrome浏览器里字体显示仍为12px,这时可以用 html{-webkit-text-size-adjust:none;}

    2、-webkit-text-size-adjust放在body上会导致页面缩放失效

    3、body会继承定义在html的样式

    4、用-webkit-text-size-adjust不要定义成可继承的或全局的

    举个例子:

    html {
        color: #000;
        background: #fff;
        overflow-y: scroll;
        -webkit-text-size-adjust: 100%;
        -ms-text-size-adjust: 100%
    }
    
    html * {
        outline: 0;
        -webkit-text-size-adjust: none;
        -webkit-tap-highlight-color: rgba(0,0,0,0)
    }

    或者:

    * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
        outline: 0;
        -webkit-tap-highlight-color: transparent
    }
    
    html {
        -webkit-text-size-adjust: none;
        -webkit-font-smoothing: antialiased;
    }

  • 相关阅读:
    正向代理和反向代理
    CFree5构建中止问题
    [转]Prototype核心成员的反思
    解决js文件乱码问题
    【WPF开发备忘】使用MVVM模式开发中列表控件内的按钮事件无法触发解决方法
    rem 搭配 less 适配
    中国近代史-蒋廷黻
    docker 生成镜像 上传到docker hub
    CMD 执行 Python 脚本 出现假死状态
    vue 创建项目的两种方式
  • 原文地址:https://www.cnblogs.com/joe235/p/14472962.html
Copyright © 2011-2022 走看看