;(function(win,lib) { var doc = win.document; var docEl = doc.documentElement; var MetaEl = doc.querySelector('Meta[name="viewport"]'); var flexibleEl = doc.querySelector('Meta[name="flexible"]'); var dpr = 0; var scale = 0; var tid; var flexible = lib.flexible || (lib.flexible = {}); if (MetaEl) { console.warn('将根据已有的Meta标签来设置缩放比例'); var match = MetaEl.getAttribute('content').match(/initial\-scale=([\d\.]+)/); if (match) { scale = parseFloat(match[1]); dpr = parseInt(1 / scale); } } else if (flexibleEl) { var content = flexibleEl.getAttribute('content'); if (content) { var initialDpr = content.match(/initial\-dpr=([\d\.]+)/); var maximumDpr = content.match(/maximum\-dpr=([\d\.]+)/); if (initialDpr) { dpr = parseFloat(initialDpr[1]); scale = parseFloat((1 / dpr).toFixed(2)); } if (maximumDpr) { dpr = parseFloat(maximumDpr[1]); scale = parseFloat((1 / dpr).toFixed(2)); } } } if (!dpr && !scale) { var isAndroid = win.navigator.appVersion.match(/android/gi); var isIPhone = win.navigator.appVersion.match(/iphone/gi); var devicePixelRatio = win.devicePixelRatio; //var isRegularDpr = devicePixelRatio.toString().match(/^[1-9]\d*$/g); if (isIPhone) { // 对于2和3的屏,用2倍的方案,其余的用1倍方案 if (devicePixelRatio >= 3 && (!dpr || dpr >= 3)) { dpr = 3; } else if (devicePixelRatio >= 2 && (!dpr || dpr >= 2)){ dpr = 2; } else { dpr = 1; } } else { // 其他设备下,仍旧使用1倍的方案 dpr = 1; } scale = 1 / dpr; } docEl.setAttribute('data-dpr',dpr); if (!MetaEl) { MetaEl = doc.createElement('Meta'); MetaEl.setAttribute('name','viewport'); //Android target-densitydpi=device-dpi var attribute = 'initial-scale=' + scale + ',maximum-scale=' + scale + ',minimum-scale=' + scale + ',user-scalable=no'; //判断是否是WebView var app = getCookie('chelun_appName'); if(app) { attribute = 'width=device-width,'+attribute; } MetaEl.setAttribute('content',attribute); if (docEl.firstElementChild) { docEl.firstElementChild.appendChild(MetaEl); } else { var wrap = doc.createElement('div'); wrap.appendChild(MetaEl); doc.write(wrap.innerHTML); } } function getCookie(name){ var maps = {}; var cookArr = document.cookie.split(';') for(var i in cookArr){ var tmp = cookArr[i].replace(/^\s*/,''); if(tmp){ var nv = tmp.split('='); maps[nv[0]] = nv[1] || ''; } } return maps[name]; } function refreshRem(){ var width = docEl.getBoundingClientRect().width; if (width / dpr > 540) { width = 540 * dpr; } var rem = width / 10; docEl.style.fontSize = rem + 'px'; flexible.rem = win.rem = rem; } win.addEventListener('resize',function() { clearTimeout(tid); tid = setTimeout(refreshRem,300); },false); win.addEventListener('pageshow',function(e) { if (e.persisted) { clearTimeout(tid); tid = setTimeout(refreshRem,300); } },false); if (doc.readyState === 'complete') { //doc.body.style.fontSize = 12 * dpr + 'px'; } else { doc.addEventListener('DOMContentLoaded',function(e) { //doc.body.style.fontSize = 12 * dpr + 'px'; },false); } refreshRem(); flexible.dpr = win.dpr = dpr; flexible.refreshRem = refreshRem; flexible.rem2px = function(d) { var val = parseFloat(d) * this.rem; if (typeof d === 'string' && d.match(/rem$/)) { val += 'px'; } return val; } flexible.px2rem = function(d) { var val = parseFloat(d) / this.rem; if (typeof d === 'string' && d.match(/px$/)) { val += 'rem'; } return val; } })(window,window['lib'] || (window['lib'] = {}));
引入flexible.js
这一步其实非常简单,只要把flexible.js的内容复制出来,在本地新建一个flexible.js的文件,打开粘贴进去就可以了,我把这个文件放在了js/lib下面:
接着在html页面里面,尽可能早的引入这个js文件(为了让适配的效果更快):
注:使用lib-flexible,通常不要写:
<Meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no"/>
交给flexible.js自动处理。
然后在chrome的模拟器里面,选择iphone6,应该就能看到html的font-size已经被设置为font-size: 75px了:
3. 编写CSS
基本要求:
1)除font-size外,其它大小都根据750标注稿的尺寸,转换成rem单位的值,转换方法为:标注稿尺寸 / 标注稿基准字体大小;
2)标注稿基准字体大小 = 标注稿宽度 / 10,如标注稿宽为750,标注稿基准字体大小为75;标注稿宽为640,标注稿基准字体大小为64;(所以淘宝这个方案是可以在任意设计稿尺寸下使用的)
3)如果需要设置font-size,可跟据html的data-dpr属性来处理,类似下面的写法:
以安卓下载按钮的样式为例,说明这种用法。android.png的尺寸为:414*80,所以css这么写: