基于webpack4+vue-cli3项目实现换肤功能
起因
最近因公司需求,需要实现主题换肤功能,不仅仅是颜色的更改,还需要包括图片,字体等文件等更换,因此在百度里各种实现方案后,决定根据scss+style-loader/useable
做换肤。
项目开始
首先我们用vue-element-admin
这个开源的后台管理系统项目来做demo演示,为了便于做二次开发,下载vue-admin-template来开发。
// 从github下载vue-admin-template clone https://github.com/PanJiaChen/vue-admin-template.git cd vue-admin-template npm install npm run dev
运行成功后的效果
安装style-loader处理器
因为vue-admin-template
项目是添加过sass-loader
依赖的,所以不用我们再次安装,在上一步就已经安装好了。
npm install style-loader --save-dev
创建主题文件
在src目录下创建theme-chalk、theme-light
主题文件夹
在两个主题目录下创建index.useable.scss文件 
在index.useable.scss
中写入样式
// theme-chalk/index.useable.scss body { background: red; } // theme-light/index.useable.scss body { background: green; }
到此,我们的主题样式都已经建好了,现在要将主题应用上去
在vue.config.js中增加style-loader/useable
vue-cli2根vue-cli3的配置区别还是挺大的,我在配置的过程中遇到很多坑,因为vue-cli3没有了webpack.config.js文件,我们在配置webpack的时候无法根据老文档来配置,需要熟悉cli3的webpack-chain来链式修改配置,但是文档很少,配置的过程中异常困难。
在配置文件中chainWebpack链式修改webpack配置就能成功应用loader了,话不多说,直接上代码,
// 换肤loader const scss = config.module.rule('scss').toConfig(); const useable = { ...scss.oneOf[3], test: /\.useable.scss$/ }; useable.use = [...useable.use]; useable.use[0] = { loader: 'style-loader/useable' }; config.module.rule('scss').merge({ oneOf: [useable] });
使用主题
在准备工作都做好后,接下来我们开始使用主题样式。
之前说的为什么要用style-loader
来做换肤呢?是因为style-loader提供了useable这一API,可动态加载删除link文件。具体详情请自行去看看style-loader。
在src目录下,创建theme.js文件
const cache = {}; const themeAction = { chalk() { if (!cache.chalk) { cache.chalk = import('./styles/theme-chalk/index.useable.scss'); } return cache.chalk; }, light() { if (!cache.light) { cache.light = import('./styles/theme-light/index.useable.scss'); } return cache.light; } }; let current = null; async function setTheme(theme) { if (themeAction[theme]) { const style = await themeAction[theme](); if (current) { current.unref(); } style.ref(); current = style; } } window.setTheme = setTheme; export default setTheme;
在main.js中,引入theme.js。
import setTheme from './theme' // 使用主题 setTheme('chalk')
重启服务,查看效果
在实际项目中,可根据传入的主题(chalk/light),动态切换主题色,同时也可根据业务需求,创建多个主题。我们只需要在index.useable.scss文件中写样式变量即可。
总结
以上所述是小编给大家介绍的基于webpack4+vue-cli3项目实现换肤功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
您可能感兴趣的文章:
- 基于webpack4+vue-cli3项目的换肤功能
- 基于webpack4+vue-cli3项目的换肤功能
- webpack搭建vue项目,实现脚手架功能
- 基于Vue 和 webpack的项目实现
- 使用webpack搭建vue项目实现脚手架功能
- 基于Webpack, KnockoutJs,esyui,koeasyui实现类vue-cli生成的模板框架
- vue 使用vue-cli打包工具生成基于webpack模板的项目
- 使用webpack搭建vue项目实现脚手架功能
- vue-cli项目开发/生产环境代理实现跨域请求+webpack配置开发/生产环境的接口地址
- Vue-Cli 搭建——基于 webpack 的 vue.js 项目
- vue-cli3+ts+webpack实现多入口多出口功能
- vue-cli起的webpack项目 用localhost可以访问,但是切换到ip就不可以访问 我用的是vux起的一个项目(移动端,基于vue的),因为是移动端的,需要在手机上测试,发现用
- vue-cli+webpack实现多页面应用的配置
- vue-cli 快速构建vue应用,实现webpack打包
- vue-cli+webpack项目 修改项目名称
- vue-cli的webpack模板项目配置文件分析
- vue-cli webpack2项目打包优化
- csdn上看到的一篇关于vue-cli的webpack模板项目配置文件分析
- vue-cli的webpack模板项目配置文件的理解
- vue-cli的webpack模版项目配置解析