网络编程 发布日期:2025/11/6 浏览次数:1
需求:由于业务需要,我们需要做多套皮肤
调研了下当前行业的实现方案,五花八门良莠不齐,在此总结下各种方案有优劣及复杂度,供大家快速定位到符合自己业务的方案,以vue 单页应用为业务场景
方式一:class切换方式
实现:
在每个需要更换的页面定义多个class,根据运行时标识动态的切换class名称实现加载不同的样式,这种方式较为简单
优点:
缺点:
方式二:ElementUI的实现
实现:
对主题涉及的颜色使用特殊值
如:UI需要白色#ffffff色值的时候使用一个相近的特征值颜色 如:#fffffe
// 将默认样式特征值替换为变量,用于多次替换
getStyleTemplate(data) {
const colorMap = {
'#fffffe': 'text_color'
};
Object.keys(colorMap).forEach(key => {
const value = colorMap[key];
data = data.replace(new RegExp(key, 'ig'), value);
});
return data;
},
在代码运行时动态获取到需要修改的颜色值
如: 需要修改#fffffe =》 #ff00ff
// 通过用户操作或者接口,获取到要替换的色值
colors:{
text_color: '#ff00ff'
}
查找页面所有style标签将其色值#fffffe正则匹配出来,替换为 #ff00ff
// 获取默认样式,可以从已加载的 style 中获取也可以从 css link 获取
getIndexStyle() {
document.querySelectorAll('style').forEach(item=>{
this.originalStyle += this.getStyleTemplate(item.textContent);
})
},
getCssLink(){
this.get('./cssPath.css').then(json=>{
this.originalStyle = this.getStyleTemplate(json.data);
})
}
在页面新加标签style覆盖默认值
// 替换默认样式表,插入 style 标签覆盖样式
writeNewStyle() {
let cssText = this.originalStyle;
log(cssText)
Object.keys(this.colors).forEach(key => {
cssText = cssText.replace(new RegExp('(:|\\s+)' + key, 'g'), '$1' + this.colors[key]);
});
cssText = cssText.replace(/\n/g,'')
if (this.originalStylesheetCount === document.styleSheets.length) {
const style = document.createElement('style');
style.innerText = cssText;
document.head.appendChild(style);
} else {
document.head.lastChild.innerText = cssText;
}
},
优点:
缺点:
const ExtractTextPlugin = require('extract-text-webpack-plugin')
// 抽离css
module: {
loaders: [
{//抽离css 通过link加载
test: /\.css$/,
loader: ExtractTextPlugin.extract({
fallback: 'style-loader',
use: 'css-loader'
})
}
...
plugins: [
new ExtractTextPlugin({
filename: 'css/[name].css'
allChunks: true // 打包所有页面css到同一个css 文件
})
]
方式三:编译时多主题全量构建
实现:
优点:
配合 rel="alternate stylesheet" 可预加载备选主题样式
方式四: 编译时选择性构建
实现:
优点:
缺点:
方式五:less动态变量
实现:
less: {
modifyVars: {},
javascriptEnabled: true
}
优点:
缺点:
方式六:css变量
实现:
在需要变化的css属性定义变量
:root {
--main-bg-color: pink;
}
body {
background-color: var(--main-bg-color);
}
在运行时动态的修改变量
document.body.style.setProperty('--primary', '#7F583F');
优点:
缺点:
ios Safari 9.3、 android 5、 chrome forAndroid 76UC、QQ、Baidu 等国内浏览器支持度较差
方式七: import动态加载
实现:
if(a){
import('./thems/a/base.less')
}else if(b){
import('./thems/b/base.less')
}
优点:
缺点:
方式
动态切换
动态色值
支持变量
实现复杂度
兼容性
性能
维护性
class切换方式
是
否
是
简单
良好
良好
ElementUI的实现
是
是
是
中等
良好
一般
编译时多主题全量构建
是
否
是
复杂
良好
一般
编译时选择性构建
否
否
是
中等
良好
良好
less变量
是
是
否
复杂
良好
差
css变量
是
是
是
中等
差
良好
import动态加载
是
否
否
简单
良好
良好
注:
参考资料:
https://panjiachen.github.io/vue-element-admin-site/zh/guide/advanced/theme.html#样式覆盖
https://developer.mozilla.org/zh-CN/docs/Web/CSS/Alternative_style_sheets
https://less.bootcss.com
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。