详解vue项目中如何引入全局sass/less变量、function、mixin
程序员文章站
2022-05-25 22:24:46
让我们考虑下场景:当使用rem/vw开发移动端的时候,你定义了一个px转rem的函数,或者是网站配色的全局变量等,然后到工程里为每个vue文件或者组件@import ‘pu...
让我们考虑下场景:当使用rem/vw开发移动端的时候,你定义了一个px转rem的函数,或者是网站配色的全局变量等,然后到工程里为每个vue文件或者组件@import ‘publicfilename.scss',那得重复做这样的工作很多很多...次,万一这些公用文件目录路径变怎么办呢,哭都来不及,想想都觉得恐怖呀!
接下来拯救我们的神器就要登场了,它可以省去重复性的引入,还支持less,postcss等,具体用法如下:
npm install -d sass-resource-loader
首先我们找到项目里build目录,在该目录下找到util.js
更新前util.js代码如下:
'use strict' const path = require('path') const config = require('../config') const extracttextplugin = require('extract-text-webpack-plugin') const packageconfig = require('../package.json') exports.assetspath = function (_path) { const assetssubdirectory = process.env.node_env === 'production' ? config.build.assetssubdirectory : config.dev.assetssubdirectory return path.posix.join(assetssubdirectory, _path) } exports.cssloaders = function (options) { options = options || {} const cssloader = { loader: 'css-loader', options: { sourcemap: options.sourcemap } } // generate loader string to be used with extract text plugin function generateloaders (loader, loaderoptions) { const loaders = options.usepostcss ? [cssloader, postcssloader] : [cssloader] if (loader) { loaders.push({ loader: loader + '-loader', options: object.assign({}, loaderoptions, { sourcemap: options.sourcemap }) }) } // extract css when that option is specified // (which is the case during production build) if (options.extract) { return extracttextplugin.extract({ use: loaders, fallback: 'vue-style-loader' }) } else { return ['vue-style-loader'].concat(loaders) } } // https://vue-loader.vuejs.org/en/configurations/extract-css.html return { css: generateloaders(), postcss: generateloaders(), less: generateloaders('less'), sass: generateloaders('sass', { indentedsyntax: true }), scss: generateloaders('sass'), stylus: generateloaders('stylus'), styl: generateloaders('stylus') } } // generate loaders for standalone style files (outside of .vue) exports.styleloaders = function (options) { const output = [] const loaders = exports.cssloaders(options) for (const extension in loaders) { const loader = loaders[extension] output.push({ test: new regexp('\\.' + extension + '$'), use: loader }) } return output } exports.createnotifiercallback = () => { const notifier = require('node-notifier') return (severity, errors) => { if (severity !== 'error') return const error = errors[0] const filename = error.file && error.file.split('!').pop() notifier.notify({ title: packageconfig.name, message: severity + ': ' + error.name, subtitle: filename || '', icon: path.join(__dirname, 'logo.png') }) } } /** * 增加 hljs 的 classname */ exports.wrapcustomclass = function (render) { return function (...args) { return render(...args) .replace('<code class="', '<code class="hljs ') .replace('<code>', '<code class="hljs">') } } /** * format html string */ exports.converthtml = function (str) { return str.replace(/()(\w{4});/gi, $0 => string.fromcharcode(parseint(encodeuricomponent($0).replace(/(%26%23x)(\w{4})(%3b)/g, '$2'), 16))) }
看util.js文件,我们首先找到我需要修改目标在哪:
// https://vue-loader.vuejs.org/en/configurations/extract-css.html return { css: generateloaders(), postcss: generateloaders(), less: generateloaders('less'), sass: generateloaders('sass', { indentedsyntax: true }), scss: generateloaders('sass'), stylus: generateloaders('stylus'), styl: generateloaders('stylus') }
我们那sass为例,用sass-resources-loader对其改造:
/** * sass less 源文件 * @param name classfile * @returns {string} */ function resolveresouce(name) { return path.resolve(__dirname, '../static/' + name); } //导入全局sass mixin function等 function generatesassresourceloader(){ var loaders = [ cssloader, //'postcss-loader', 'sass-loader', { loader:'sass-resources-loader', options: { //需要一个全局路径 resources: [resolveresouce('index.scss')] } } ] if(options.extract){ return extracttextplugin.extract({ use:loaders, fallback: 'vue-style-loader' }) }else{ return ['vue-style-loader'].concat(loaders) } }
工具写好好了,接下来直接把上门return对象做些调整,代码如下
// https://vue-loader.vuejs.org/en/configurations/extract-css.html return { css: generateloaders(), postcss: generateloaders(), less: generateloaders('less'), sass:generatesassresourceloader(), scss:generatesassresourceloader(), stylus: generateloaders('stylus'), styl: generateloaders('stylus') }
从代码中可以看出,我们把sass和scss的loader换成我们自己根据sass-resources-loader写的方法了,这样就实现了我们的目标。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 实例解析php的数据类型
下一篇: Angular 封装并发布组件的方法示例