摘要:最近项目中要实现一个换肤的功能,大体想了下,记录一下思路要实现换肤功能,目标就是打包生成多份皮肤文件,需要哪个就用哪个打包生成多份皮肤文件因为项目是使用构建的,要想生成多份文件,就要在入口中配置多个入口文件,每个入口文件会提取出一个文件中整
source
最近项目中要实现一个换肤的功能,大体想了下,记录一下思路
要实现换肤功能,目标就是打包生成多份皮肤文件,需要哪个就用哪个
打包生成多份皮肤文件因为项目是使用webpack构建的,要想生成多份css文件,就要在入口中配置多个入口文件,每个入口文件会提取出一个css文件
config.entry={
app: ["./src/app.js"],
defaultTheme: ["./src/theme.default.color.js"],
orangeTheme:["./src/theme.orange.color.js"],
blueTheme:["./src/theme.blue.color.js"],
}
app.js中
import "./app.styl" //整个项目的样式,在各种皮肤下都保持不变的那部分
theme.blue.color.js 蓝色皮肤js文件
import "./theme/blue.styl"
blue.styl 蓝色皮肤
@require "./css/skinTheme/var.blue" //样式变量,整体为蓝色风格的颜色值
@require "./css/skinTheme/theme.color" //提取出来的需要换肤的那部分样式
如代码所示,几个主题js文件中只是单纯的引入了相应的皮肤样式文件,这样,webpack打包后就会生成几个无用的js文件和一系列皮肤样式文件
到这一步,就得到了需要的皮肤文件,但是需要注意的是,webpack会将生成的js、css路径插入到模板html中,所以,我们打开构建后生成index.html会看到
操作index.html
接下来就需要操作打包后的index.html,将多余的js引用删掉,将皮肤路径提取出来,然后将皮肤引用删掉
也就是要改成这样的文件
/build/index.html
可以写这样一个操作文件的函数
cssExtract.js
const DISTPATH = "build/index.html"
const cheerio = require("cheerio")
const fs = require("fs")
const chalk = require("chalk")
const prefix = ["defaultTheme", "orangeTheme", "blueTheme"]
const cssUrls = {}
function extractCss() {
fs.readFile(DISTPATH, "utf8", (err, data) => {
if (err) {
throw err
}
const $ = cheerio.load(data)
/**
* 删除所有主题css,相关链接保存在window.cssUrls中
*/
$("link").each((index, item) => {
const href = $(item).attr("href")
for (const val of prefix) {
if (href.indexOf(val) !== -1) {
cssUrls[val] = href
$(item).remove()
}
}
})
/**
* 删除无用的js
*/
$("script").each((index, item) => {
const src = $(item).attr("src")
for (const val of prefix) {
if (src && src.indexOf(val) !== -1) {
$(item).remove()
}
}
})
//插入行内js
$("base").after(``)
fs.writeFile(DISTPATH, $.html(), err => {
if (err) {
throw err
}
console.log(chalk.cyan("extract css url complete.
"))
})
})
}
extractCss()
最后
到这里,运行 webpack && node cssExtract.js,index.html就变成上面期望的那样,我们得要了皮肤文件的一个mapping,并保存在window.cssUrls中,接下来,通过切换按钮的方式切换皮肤还是什么其他的就可以自由发挥了.
需要说明的是,换肤功能的重点是对样式的重构,将需要换肤的所有样式提取到一起,通过变量来设置不同的主题
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/54430.html
摘要:最近项目中要实现一个换肤的功能,大体想了下,记录一下思路要实现换肤功能,目标就是打包生成多份皮肤文件,需要哪个就用哪个打包生成多份皮肤文件因为项目是使用构建的,要想生成多份文件,就要在入口中配置多个入口文件,每个入口文件会提取出一个文件中整 source 最近项目中要实现一个换肤的功能,大体想了下,记录一下思路 要实现换肤功能,目标就是打包生成多份皮肤文件,需要哪个就用哪个 打包生成多...
摘要:最近项目中要实现一个换肤的功能,大体想了下,记录一下思路要实现换肤功能,目标就是打包生成多份皮肤文件,需要哪个就用哪个打包生成多份皮肤文件因为项目是使用构建的,要想生成多份文件,就要在入口中配置多个入口文件,每个入口文件会提取出一个文件中整 source 最近项目中要实现一个换肤的功能,大体想了下,记录一下思路 要实现换肤功能,目标就是打包生成多份皮肤文件,需要哪个就用哪个 打包生成多...
摘要:社区的认可目前已经是相关最多的开源项目了,体现出了社区对其的认可。监听事件手动维护列表这样我们就简单的完成了拖拽排序。 完整项目地址:vue-element-admin 系类文章一:手摸手,带你用vue撸后台 系列一(基础篇)系类文章二:手摸手,带你用vue撸后台 系列二(登录权限篇)系类文章三:手摸手,带你用vue撸后台 系列三(实战篇)系类文章四:手摸手,带你用vue撸后台 系列...
摘要:社区的认可目前已经是相关最多的开源项目了,体现出了社区对其的认可。监听事件手动维护列表这样我们就简单的完成了拖拽排序。 完整项目地址:vue-element-admin 系类文章一:手摸手,带你用vue撸后台 系列一(基础篇)系类文章二:手摸手,带你用vue撸后台 系列二(登录权限篇)系类文章三:手摸手,带你用vue撸后台 系列三(实战篇)系类文章四:手摸手,带你用vue撸后台 系列...
摘要:项目搭建用的,框架选择的首先安装支持然后去文件夹下的文件中,添加对的支持准备工作做好了,开始换肤新建一个文件夹,在里面新建一个文件定义一个方法,写上需要的颜色参数如图文件夹下再新建一个存放各类主题的文件,里面根据自己需求定义各类主题 项目搭建用的vue—cli,css框架选择的iview1、首先安装less支持 npm install --save-dev less-loader le...
阅读 2699·2023-04-26 02:57
阅读 1585·2023-04-25 21:40
阅读 2488·2021-11-24 09:39
阅读 3740·2021-08-30 09:49
阅读 912·2019-08-30 15:54
阅读 1302·2019-08-30 15:52
阅读 2325·2019-08-30 15:44
阅读 1402·2019-08-28 18:27
极致性价比!云服务器续费无忧!
Tesla A100/A800、Tesla V100S等多种GPU云主机特惠2折起,不限台数,续费同价。
NVIDIA RTX 40系,高性价比推理显卡,满足AI应用场景需要。
乌兰察布+上海青浦,满足东推西训AI场景需要