rem.js 1.2 KB

1234567891011121314151617181920212223242526
  1. !(function(window) {
  2. /* 设计图文档宽度 */
  3. var docWidth = 750;
  4. var doc = window.document,
  5. docEl = doc.documentElement,
  6. resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';
  7. var recalc = (function refreshRem() {
  8. var clientWidth = docEl.getBoundingClientRect().width;
  9. /* 8.55:小于320px不再缩小,11.2:大于420px不再放大 */
  10. docEl.style.fontSize = Math.max(Math.min(20 * (clientWidth / docWidth), 11.2), 8.55) * 5 + 'px';
  11. return refreshRem;
  12. })();
  13. /* 添加倍屏标识,安卓为1 */
  14. docEl.setAttribute('data-dpr', window.navigator.appVersion.match(/iphone/gi) ? window.devicePixelRatio : 1);
  15. if (/iP(hone|od|ad)/.test(window.navigator.userAgent)) {
  16. /* 添加IOS标识 */
  17. doc.documentElement.classList.add('ios');
  18. /* IOS8以上给html添加hairline样式,以便特殊处理 */
  19. if (parseInt(window.navigator.appVersion.match(/OS (\d+)_(\d+)_?(\d+)?/)[1], 10) >= 8)
  20. doc.documentElement.classList.add('hairline');
  21. }
  22. if (!doc.addEventListener)
  23. return;
  24. window.addEventListener(resizeEvt, recalc, false);
  25. doc.addEventListener('DOMContentLoaded', recalc, false);
  26. })(window);