这篇文章主要介绍了Vue-cli3.X使用px2rem遇到的问题及解决方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
把项目脚手架升级为cli3.X了以后,模板简洁了很多,运行起来也更加快速。但是也随之而来是某些兼容问题。比如我们要在项目钟使用px2rem来计算设计稿的时候,我们不能像以前老的脚手架那样操作了。那我们应该来如何设置呢?
首先,我们应该用NPM来安装postcss-px2rem
npm i postcss-plugin-px2rem --save -dev
然后我们需要在vue.config.js中创建一个配置。由于在vue-cli3.X中。去掉了build和config文件夹。所有的配置都放到了vue.config.js,然而这个文件脚手架并没有生成,所以需要手动在项目的根目录创建一个文件
在vue.config.js里配置
module.exports = {
lintOnSave: true,
css: {
loaderOptions: {
postcss: {
plugins: [
require('postcss-plugin-px2rem')({
rootValue:75, // 新版本的是这个值
mediaQuery: false, //(布尔值)允许在媒体查询中转换px。
minPixelValue: 3 //设置要替换的最小像素值(3px会被转rem)。 默认 0
}),
]
}
}
},
}
要说明一点。网上搜的一堆教程都强调应该增加remUnit来设置rem的计算标准。但是其实在新版后,这个值换成了rootValue这个。例如你设计稿为750的宽度标准,那么这里的值设置为75则可。
接下来还有一个工作。由于rem是根据根字体的大小来作为基准值的,然而我们的移动设备屏幕大小以及有些屏幕为视网膜屏的,会是普通屏幕的2倍,所以这个基准值我们需要根据不同设备来进行计算。这里我们在src/plugins下新建一个rem.js文件(代码如下)。
(function(win, lib) {
vardoc = win.document;
vardocEl = doc.documentElement;
varmetaEl = doc.querySelector('meta[name="viewport"]');
varflexibleEl = doc.querySelector('meta[name="flexible"]');
vardpr = 0;
varscale = 0;
vartid;
varflexible = lib.flexible || (lib.flexible = {});
if(metaEl) {
//console.warn('将根据已有的meta标签来设置缩放比例');
varmatch = metaEl.getAttribute('content').match(/initial\-scale=([\d\.]+)/);
if(match) {
scale = parseFloat(match[1]);
dpr = parseInt(1 / scale);
}
} elseif(flexibleEl) {
varcontent = flexibleEl.getAttribute('content');
if(content) {
varinitialDpr = content.match(/initial\-dpr=([\d\.]+)/);
varmaximumDpr = 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) {
varisAndroid = win.navigator.appVersion.match(/android/gi);
varisIPhone = win.navigator.appVersion.match(/iphone/gi);
vardevicePixelRatio = win.devicePixelRatio;
if(isIPhone) {
// iOS下,对于2和3的屏,用2倍的方案,其余的用1倍方案
if(devicePixelRatio >= 3 && (!dpr || dpr >= 3)) {
dpr = 3;
} elseif(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{
varwrap = doc.createElement('div');
wrap.appendChild(metaEl);
doc.write(wrap.innerHTML);
}
}
functionrefreshRem() {
varwidth = docEl.getBoundingClientRect().width;
if(width / dpr > 540) {
width = 540 * dpr;
}
varrem = 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) {
varval = parseFloat(d) * this.rem;
if(typeofd === 'string'&& d.match(/rem$/)) {
val += 'px';
}
returnval;
}
flexible.px2rem = function(d) {
varval = parseFloat(d) / this.rem;
if(typeofd === 'string'&& d.match(/px$/)) {
val += 'rem';
}
returnval;
}
})(window, window['lib'] || (window['lib'] = {}));
然后在main.js里面引入该文件
import './plugins/rem.js'
这样,我们的工作就完成了。可以直接在css里面写px的绝对值。
总结: 以上所述是小编给大家介绍的Vue-cli3.X使用px2 rem遇到的问题及解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!