词条信息

admin
admin
超级管理员
词条创建者 发短消息   

相关词条

热门词条

更多>>
宽带升级到200兆了,路由器和网线是不是需要更换?
事实上,200兆宽带需要支持千兆网络传输速率的硬件。尽管200兆与千兆相差很大,但目前网络传输速率只有百兆和千...
2019年电子商务发展4大主流趋势
随着在线零售业的竞争日趋激烈,企业和卖家只有积极利用科技趋势才能保住增长势头,立于不败之地。据市场研究公司 S...
超1亿人朋友圈“仅三天可见”
你有多少个真正称得上朋友的人?前段时间微信创始人、腾讯公司高级副总裁张小龙在年度演讲里说起关于朋友圈的一件事:...
半夜总是醒了又睡睡了又醒怎么办?
现在是一个全民缺觉的时代,越来越多人因为加班、情感、焦虑等问题困扰着自己的失眠。急剧下降的睡眠质量,同样也会影...
敬酒时,应先敬己方领导还是对方领导
敬酒时,应先敬己方领导还是对方领导?己方领导未敬酒或无敬酒意思员工该不该敬?首先看第一个问题,如果一个桌上既有...
解决网 >>所属分类 >> CSS   

rem布局获得分辨率方法

标签: rem 分辨率

顶[0] 发表评论(0) 编辑词条

不是所有元素都需要缩放的。


最容易举例的就是1px的border,无论什么屏,无论像素密度多少,都要准确的显示1物理像素


淘宝目前的做法即是,通过脚本检测设备的像素密度,再设置文档的根font-size与viewport的缩放值,从而让px能够准确的显示为物理像素。


我们的做法是:获取设备像素密度后,设置根节点的fontSize,然后文档中全部使用rem+px结合。


window.onload = function () {

    var nameAttr = document.createAttribute('name');

    nameAttr.value = 'viewport';

    var contentAttr = document.createAttribute('content');

    var dpr = window.devicePixelRatio || 1;

    contentAttr.value = 'width=device-width,initial-scale=' + (1 / dpr) + ',target-densitydpi=device-dpi,user-scalable=no';

    var element = document.createElement('meta');

    element.attributes.setNamedItem(nameAttr);

    element.attributes.setNamedItem(contentAttr);

    document.head.appendChild(element);

    document.getElementsByTagName('html')[0].style.fontSize = (16 * dpr) + 'px';

};

目前兼容良好。

 

 

附件列表


按字母顺序浏览:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

→我们致力于为广大网民解决所遇到的各种电脑技术问题
 如果您认为本词条还有待完善,请 编辑词条

上一篇纯css3显示隐藏一个div特效
下一篇CSS3中px,em,REM使用详解

0
1. 本站部分内容来自互联网,如有任何版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
2. 本站内容仅供参考,如果您需要解决具体问题,建议您咨询相关领域专业人士。
3. 如果您没有找到需要的百科词条,您可以到百科问答提问或创建词条,等待高手解答。

关于本词条的提问

查看全部/我要提问>>