阅读模式:

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

查看:7019  回复: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也是一样。

二、简单js代码设置

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

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

扫描二维码手机查看

发布评论:


登录:
  表情:
评论话题
推荐阅读:
网站局部小图片优化-base64编码图片   阅读:19080ajax+php 实现一个简单的在线聊天室功能(附带源码)   阅读:10052php打印三角形   阅读:10846解决 nginx 413 request entity too large   阅读:4750centos 7搭建zabbix3.4   阅读:6914nginx安装mysql和json模块   阅读:5600linux php7编译安装mongodb扩展   阅读:9323分享:淘宝技术这十年   阅读:4977php文件下载防盗链   阅读:10283封装php redis缓存操作类   阅读:9552centos 7 忘记root密码   阅读:5162栈和堆的区别   阅读:5345php压缩页面的html代码一行显示   阅读:7962最新centos7 搭建LNMP环境(centos7.2+php7+mysql5.7+nginx1.11+redis3.2)   阅读:11396shell脚本统计当前服务器并发连接数   阅读:8089程序员找工作三要素(必看)   阅读:5950解决 nginx 413 request entity too large   阅读:4750php翻转字符串   阅读:3843centos 7 开启网络   阅读:7429小米手机端商城rem适配原理   阅读:7020linux教程,鸟哥私房菜(pdf全集)   阅读:10547最新centos7 搭建LNMP环境(centos7.2+php7+mysql5.7+nginx1.11+redis3.2)   阅读:11396centos 7 忘记root密码   阅读:5162面试都会问你为什么你从上一家公司离职的真实意思   阅读:11548centos 7 安装 redis 3.2.9   阅读:6924centos 7 设置 nginx-1.11.10 开机启动   阅读:8317web项目高并发量网站解决方案   阅读:4936javascript获取两个日期间的所有日期   阅读:7091centos 7 设置 nginx-1.11.10 开机启动   阅读:8317mysql中文分词全文搜索索引讯搜的安装   阅读:7300TCP的三次握手(建立连接)和四次挥手(关闭连接)   阅读:4050“米粉节”背后的故事——小米网抢购系统开发实践   阅读:4418栈和堆的区别   阅读:5345centos 7搭建zabbix3.4   阅读:6914php+redis实现消息队列   阅读:15489php翻转字符串   阅读:3843封装php redis缓存操作类   阅读:9552Mysql在大型网站的应用架构演变   阅读:4976php冒泡排序法   阅读:14868crontab+shell脚本实现定时备份mysql数据库   阅读:8044php打印九九加法表   阅读:11182centos 7 开启网络   阅读:7429一键分享到QQ空间、QQ好友、新浪微博、微信代码   阅读:132796centos 7 开启网络   阅读:7429php 获取当前前后年、月、星期、日、时分秒的时间   阅读:7102centos 7搭建zabbix3.4   阅读:6914php连接redis   阅读:5955TCP的三次握手(建立连接)和四次挥手(关闭连接)   阅读:4050给 centos 7 安装桌面环境   阅读:17305centos7中颁发CA证书并开启web https   阅读:8426