flexible.js 移动端自适应框架
;(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这么写: |
.btn {
width
414
rem/@font-size-base;
height
80
rem/@font-size-base;
由于用了less,事先定义了一个变量来保存标注稿基准字体大小:
|
.btn-android {
background-image
url
(
"../img/@2x/android.png?v=@@version"
);
?
] & {
"../img/@3x/android.png?v=@@version"
);
}
这下就OK了,原先还不知道data-dpr有什么作用,现在看看,作用还是挺大的。
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |