css-theme 通過一套源碼生成一份包含多套皮膚配置的樣式文件


css-theme

通過單一css文件生成多套主題,並合並入一個css文件中

特性

  • 只加載一個css,通過切換rootClass瞬間切換主題
  • 體積壓縮,將多套css合並,去除冗余代碼,避免文件體積膨脹
  • 低侵入性,不改變現有開發模式,一處修改,全局生效

安裝

$ npm i css-theme --save-dev

使用

css編寫

在css中需要根據主題變化的地方使用占位符,占位符可以是任何字符串。
你也可以通過預處理器變量的方式向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'
    }
  ]
};

鏈接

Questions

Github

授權

MIT


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM