title
以上就是CSS Modules的基本原理.更多用法可以参考:《Ant Design Pro - 样式》
当然说那么多,也是想证明一下classnames的优秀
classnames语法
//基础用法
classNames('foo', 'bar'); // => 'foo bar'
classNames('foo', { bar: true }); // => 'foo bar'
classNames({ 'foo-bar': true }); // => 'foo-bar'
classNames({ 'foo-bar': false }); // => ''
classNames({ foo: true }, { bar: true }); // => 'foo bar'
classNames({ foo: true, bar: true }); // => 'foo bar'
// 各种各样属性结合
classNames('foo', { bar: true, duck: false }, 'baz', { quux: true }); // => 'foo bar baz quux'
// 一些不存在/空的属性会自动忽略
classNames(null, false, 'bar', undefined, 0, 1, { baz: null }, ''); // => 'bar 1'
//数组会遍历输出
var arr = ['b', { c: true, d: false }];
classNames('a', arr); // => 'a b c'
//字符串模板方式
let buttonType = 'primary';
classNames({ [`btn-${buttonType}`]: true });
通过状态控制样式的添加删除,简直不要太方便.从此告别removeClass之类方法
结合React用法
动态控制按钮样式
constructor(arg){
super(arg)
this.state = {
isPressed: false,
isHovered: true
}
}
render(){
var btnClass = classNames({
btn: true,
'btn-pressed': this.state.isPressed,
'btn-over': !this.state.isPressed && this.state.isHovered
});
return(
