css-theme如何通过源码生成一份包含多套皮肤配置的样式文件

互联网 18-10-23
本篇文章给大家带来的内容是关于css-theme如何通过源码生成一份包含多套皮肤配置的样式文件,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

css-theme

通过单一css文件生成多套主题,并合并入一个css文件中

特性

只加载一个css,通过切换rootClass瞬间切换主题

体积压缩,将多套css合并,去除冗余代码,避免文件体积膨胀

低侵入性,不改变现有开发模式,一处修改,全局生效

安装

$ npm i css-theme --save-dev

使用

css编写

@dark: #theme1; @light: #theme2;  .container {   .text1 {     font-size: 16px;     color: #theme1;     line-height: normal;   }   .text2 {     font-size: 14px;     color:  @dark;     line-height: normal;   }   .text2 {     font-size: 14px;     color: @light;     line-height: normal;   } }

gulp插件模式

在gulp任务中调用theme插件。详见 demo/gulp

var cssTheme = require('css-theme').gulp; // gulp-plugin var themeConfig = require('./theme.config'); // configs  less({   plugins:[new LessPluginTheme(themeConfig)] })

less插件模式

在通过gulp/webpack等工具调用less时,插入theme中间件。详见 demo/less

var LessPluginTheme = require('css-theme').less; // less-plugin var themeConfig = require('./theme.config'); // configs  gulp.task('default', function() {   return gulp.src('./index.less')     .pipe(less())     .pipe(cssTheme(themeConfig))     .pipe(gulp.dest('./dist')); });

配置

placeholder: 占位符,描述每个变量在css文件中对应的占位符

list: 主题列表

list.targetMap: 该主题中每个变量对应的值

list.rootClass: 使用该主题时顶层添加的class

list.default: 是否将该主题作为默认主题,在未指定class时默认展示该主题

module.exports = {   'placeholder': {     'dark': '#theme1',     'light': '#theme2'   },   'list': [     {       'default': false,       'targetMap': {         'dark': '#ff6a3a',         'light': '#ffa284',       },       'rootClass': 'skin_orange'     },     {       'default': false,       'targetMap': {         'dark': '#fdd000',         'light': '#ffd71c',       },       'rootClass': 'skin_yellow'     }   ] };

以上就是css-theme如何通过源码生成一份包含多套皮肤配置的样式文件的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: less
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:如何使用纯CSS实现打开内容弹窗的交互动画(附源码)

相关资讯