首页 > 其他 > 详细

vue换算单位px自动转换rem

时间:2019-09-28 14:57:00      阅读:148      评论:0      收藏:0      [点我收藏+]
cnpm i postcss-px2rem --save
cnpm install px2rem-loader --save

2、配置px2rem
build目录下vue-loader.conf.js中,做如下修改:

module.exports = {
loaders: utils.cssLoaders({
sourceMap: isProduction
? config.build.productionSourceMap
: config.dev.cssSourceMap,
extract: isProduction
}),
transformToRequire: {
video: src,
source: src,
img: src,
image: xlink:href
},
postcss:[require(postcss-px2rem)({remUnit:37.5,baseDpr:2})]
 
 /*因为我是以750px(iphone6)宽度为基准,所以remUnit为37.5*/
}

3、在static目录中,建js文件夹,放flex.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;
if (isIPhone) {
// iOS下,对于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);
metaEl.setAttribute(content, initial-scale= + scale + , maximum-scale= + scale + , minimum-scale= + scale + , user-scalable=no);
if (docEl.firstElementChild) {
docEl.firstElementChild.appendChild(metaEl);
} else {
var wrap = doc.createElement(div);
wrap.appendChild(metaEl);
doc.write(wrap.innerHTML);
}
}
 
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] = {}));


4、在index.html中,加入flex.js

<script type="text/javascript" src="static/js/flex.js"></script>


如果报错的话一下解决方案
仔细看了看 index.html 文件,发现原本我的 JS 文件是放在 /src/utils 文件夹下的,但引入 /src 和 /static 的文件是有区别的
解决办法是将第三方依赖的 JS 文件放到 /static/utils 目录下,引入路径也改成:<script src="./static/utils/sockjs.js"></script>,这样就不报错了

 

vue换算单位px自动转换rem

原文:https://www.cnblogs.com/wuliujun521/p/11602968.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!