React | classnames

classnames 这个库在我们的项目中有大量的使用到,它不仅很实用,还非常好用,但还有人不知道这个库,我真的是十分心痛。

通过 classnames,我们可以给组件设置多个 className,还可以根据需要动态设置 className,简化我们样式相关的逻辑代码。

css 复制代码
// 鼠标离开
.btn-leave {
  background-color: red;
  font-size: 25px;
}

// 鼠标放上
.btn-over {
  background-color: green;
  font-size: 40px;
  border-radius: 20px;
}

.btn-color {
  color: yellow;
}

.btn-margin {
  margin: 50px;
}
typescript 复制代码
import { default as classNames } from 'classnames';
import { Component } from 'react';
import './style.less';

export default class ClassnamesPage extends Component {
  render() {
    return (
      <div style={{ padding: '20px' }}>
        ClassnamesPage
        <MyComponent></MyComponent>
      </div>
    );
  }
}

class MyComponent extends Component {
  state = {
    // 鼠标是否放上去
    isMouseOver: false,
  };

  render() {
    // 设置多个className
    var btnClass = classNames('btn-color', 'btn-margin', {
      // 动态设置className,右边为true时生效
      'btn-leave': !this.state.isMouseOver,
      'btn-over': this.state.isMouseOver,
    });
    return (
      <div>
        <button
          className={btnClass}
          // 鼠标放上
          onMouseOver={() => {
            this.setState({
              isMouseOver: true,
            });
          }}
          // 鼠标离开
          onMouseLeave={() => {
            this.setState({
              isMouseOver: false,
            });
          }}
        >
          {this.state.isMouseOver ? '鼠标放上' : '鼠标离开'}
        </button>
      </div>
    );
  }
}

这个按钮,鼠标离开与放上去时的样式不一样,通过 classnames 库非常简洁直白的实现了这个功能,你真的值得拥有。

相关推荐
白兰地空瓶14 小时前
🚀你以为你在写 React?其实你在“搭一套前端操作系统”
前端·react.js
爱上妖精的尾巴14 小时前
6-4 WPS JS宏 不重复随机取值应用
开发语言·前端·javascript
似水流年QC15 小时前
深入探索 WebHID:Web 标准下的硬件交互实现
前端·交互·webhid
陪我去看海15 小时前
测试 mcp
前端
speedoooo15 小时前
在现有App里嵌入一个AI协作者
前端·ui·小程序·前端框架·web app
全栈胖叔叔-瓜州15 小时前
关于llamasharp 大模型多轮对话,模型对话无法终止,或者输出角色标识User:,或者System等角色标识问题。
前端·人工智能
三七吃山漆16 小时前
攻防世界——wife_wife
前端·javascript·web安全·网络安全·ctf
用户479492835691516 小时前
面试官问"try-catch影响性能吗",我用数据打脸
前端·javascript·面试
GISer_Jing16 小时前
前端营销技术实战:数据+AI实战指南
前端·javascript·人工智能
GIS之路16 小时前
使用命令行工具 ogr2ogr 将 CSV 转换为 Shp 数据(二)
前端