十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
背景
创新互联专注为客户提供全方位的互联网综合服务,包含不限于成都网站建设、网站设计、福州网络推广、微信小程序、福州网络营销、福州企业策划、福州品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联为所有大学生创业者提供福州建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com
在开发react项目时,很多时候我们把style写在css、less、scss里,经过像postcss这样的配置处理,但有没有这样一种需求呢,像有些样式我们直接写在xml标签上style里,然后也能进行处理,如px2rem能将px转rem,是否在style上写也能实现。
思路
我们在webpack,/.(js|jsx)?$/这样babel-loader之前(webpack从右往左)加一个loader把需要转变的px进行替换,不就好了,先找找有没有这样的loader,我找了下没找到,只能自己写一个了
代码
const loaderUtils = require('loader-utils'); // 默认参数 const defaultopts = { remUnit: 100, // rem unit value (default: 100) remFixed: 2, // rem value precision (default: 2) }; // 获取webpack配置好的参数 const opts = loaderUtils.getOptions(this); // 将参数组合 const config = Object.assign({}, defaultopts, opts); const ZPXRegExp = /\b(\d+(\.\d+)?)SUPX\b/; module.exports = function (source) { let pxGlobalRegExp = new RegExp(ZPXRegExp.source, 'g'); if (this.cacheable) { this.cacheable(); } // 先test下有没有符合的如果有再进行替换 if (pxGlobalRegExp.test(source)) { return source.replace(pxGlobalRegExp, ($0, $1) => { let val = $1 / config.remUnit; // 精确到几位 val = parseFloat(val.toFixed(config.remFixed)); return val === 0 ? val : val + 'rem'; }); } else { return source; } };
用法
{ loader: path.join(rootPath, 'loaders/jsxPx2RemLoader'), options: { remUnit: 100, remFixed: 3 } }
源代码
源码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。