欢迎来到php自学网~
阅读模式:

小米手机端商城rem适配原理

查看:2072  回复:0  类型:  来源:php自学网,小米  标签 javascript

小米源码:

function(n) {
    var e = n.document,
    t = e.documentElement,
    i = 720,
    d = i / 100,
    o = "orientationchange" in n ? "orientationchange": "resize",
    a = function() {
        var n = t.clientWidth || 320;
        n > 720 && (n = 720),
        t.style.fontSize = n / d + "px"
    };
    e.addEventListener && (n.addEventListener(o, a, !1), e.addEventListener("DOMContentLoaded", a, !1))
} (window);


小米按照720px的宽度去设置字体比例。

d = i / 100, //比例,通过这个比例去计算字体大小。

t.style.fontSize = t.clientWidth / d + "px"   //通过实时获取的屏幕宽度除以比例 就是字体新的字体大小。意思就是客户端的宽度除以比例就是当前字体的大小,比如:720/(720/100)=100px, 100px为html上的字体大小。

rem 的设置是根据网站根元素去相对改变字体大小的,所以屏幕的宽度改变字体大小也跟着改变,其他div也是一样。



其实还有一个更加简单的代码设置效果差不多:

document.documentElement.style.fontSize = document.documentElement.clientWidth/6.4+"px";




meta 缩放适配屏幕宽度

除了用rem适配之外,还有另一种更简单的宽度适配方式,通过meta标签去对屏幕缩放。

<script type="text/javascript">
var phoneWidth =  parseInt(window.screen.width);//获取屏幕的宽度
var phoneScale = phoneWidth/750; //按750px算去比例
var ua = navigator.userAgent;   //根据各种系统机型去适配缩放,就可以保证在不容设备上看的效果都是一样的了。
if (/Android (d+.d+)/.test(ua)){
    var version = parseFloat(RegExp.$1);
      if(version>2.3){
        document.write('<meta name="viewport" content="width=750, minimum-scale = '+phoneScale+',maximum-scale = '+phoneScale+', target-densitydpi=device-dpi">');
      }else{
         document.write('<meta name="viewport" content="width=750, target-densitydpi=device-dpi">');
          }
}else{
    document.write('<meta name="viewport" content="width=750, user-scalable=no, target-densitydpi=device-dpi">');
}
</script>


分享到:
0 0

*有问题之处烦请在评论中指出,非常感谢!
不是我想要的内容,继续搜索:

扫描二维码手机查看

发布评论:


登录:
  表情:
评论话题
推荐阅读:
web性能测试工具ab的测试方法   阅读:897phpexcel 超简单从数据库一键导出数据到excel教程   阅读:1415linux时间戳有趣的情人节秒1234567890   阅读:540linux php7安装yaf扩展   阅读:429移动端js触摸touch详解(附带案例源码)   阅读:2500linux top命令详解   阅读:835用php从1乘到100的值   阅读:1272session与cookie的区别   阅读:988简单的DOS攻击之死亡之ping详解   阅读:7308一步步带你,如何网站架构   阅读:816phpexcel 超简单从数据库一键导出数据到excel教程   阅读:1415Nginx 配置文件详解   阅读:943最新centos7 搭建LNMP环境(centos7.2+php7+mysql5.7+nginx1.11+redis3.2)   阅读:2219php显示刚刚、几分钟前、几小时前、几天前的函数   阅读:1231centos 7 开启网络   阅读:1051php删除一个文件夹内的所有文件夹和文件   阅读:1060javascript对cookie操作详细代码函数   阅读:956mysql5.7开启sql日志的配置   阅读:1047最简单的Banner轮播左右切换效果代码及实现思路(附带源码)   阅读:8986centos 7 忘记root密码   阅读:772比phpexcel还要简单的excel CSV 一键导入数据到数据库   阅读:1277mysql中文分词全文搜索索引讯搜的安装   阅读:867php压缩页面的html代码一行显示   阅读:1124php删除一个文件夹内的所有文件夹和文件   阅读:1060shell脚本统计当前服务器并发连接数   阅读:960移动端自适应rem原理   阅读:3912一步步带你,如何网站架构   阅读:816phpexcel 超简单从excel表格一键导入数据到数据库教程   阅读:3561linux php7编译安装mongodb扩展   阅读:510linux时间戳有趣的情人节秒1234567890   阅读:540人性漫画:打工与创业的残酷区别   阅读:858php 使用 smtp.php 类在线发送邮件功能   阅读:1208一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:3090web性能测试工具ab的测试方法   阅读:897简单的DOS攻击之死亡之ping详解   阅读:7308php生成二维码   阅读:1239一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:3090比phpexcel还要简单的excel CSV 一键导入数据到数据库   阅读:1277最新centos7 搭建LNMP环境(centos7.2+php7+mysql5.7+nginx1.11+redis3.2)   阅读:2219栈和堆的区别   阅读:773Nginx 配置文件详解   阅读:943linux时间戳有趣的情人节秒1234567890   阅读:540centos 7 安装 nginx-1.11.10   阅读:2144php设置cookie为HttpOnly防止XSS攻击   阅读:1227程序员找工作三要素(必看)   阅读:1020javascript点击复制内容   阅读:895纯干货,程序员面试的超实用技巧   阅读:732linux php7安装yaf扩展   阅读:429linux php7安装yaf扩展   阅读:429给网站添加一键qq登录的功能   阅读:1673