【React】React CSS 样式设置全攻略

在 React 中设置 CSS 样式主要有以下几种方式,各有适用场景:

1. 内联样式 (Inline Styles)

直接在 JSX 元素中使用 style 属性,值为 JavaScript 对象(使用驼峰命名法)

jsx 复制代码
function Component() {
  return (
    <div style={{ 
      color: 'red', 
      backgroundColor: 'lightblue',
      padding: '10px',
      borderRadius: '5px' // 注意驼峰命名
    }}>
      内联样式示例
    </div>
  );
}

2. 外部样式表 (External CSS)

创建独立的 .css 文件,通过 import 引入

css 复制代码
/* styles.css */
.container {
  padding: 20px;
  border: 1px solid #ccc;
  margin: 10px;
}
jsx 复制代码
import './styles.css'; // 引入样式文件

function Component() {
  return <div className="container">外部样式表示例</div>;
}

3. CSS Modules (推荐)

使用 [name].module.css 命名约定,实现局部作用域

css 复制代码
/* Component.module.css */
.error { 
  color: red;
  font-weight: bold;
}
jsx 复制代码
import styles from './Component.module.css'; // 自动生成唯一类名

function Component() {
  return <div className={styles.error}>CSS Modules 示例</div>;
}

4. CSS-in-JS 库 (如 styled-components)

通过 JavaScript 直接编写 CSS

bash 复制代码
npm install styled-components  # 先安装
jsx 复制代码
import styled from 'styled-components';

// 创建带样式的组件
const StyledButton = styled.button`
  background: ${props => props.primary ? 'blue' : 'white'};
  color: ${props => props.primary ? 'white' : 'blue'};
  padding: 10px 20px;
  border-radius: 4px;
`;

function Component() {
  return (
    <>
      <StyledButton>普通按钮</StyledButton>
      <StyledButton primary>主按钮</StyledButton>
    </>
  );
}

5. 动态样式 (根据状态变化)

结合状态管理和样式设置

jsx 复制代码
function DynamicComponent() {
  const [isActive, setIsActive] = useState(false);

  // 动态类名
  const buttonClasses = `btn ${isActive ? 'btn-active' : ''}`;
  
  // 动态内联样式
  const divStyle = {
    transform: isActive ? 'scale(1.1)' : 'none',
    transition: 'transform 0.3s'
  };

  return (
    <div>
      <div style={divStyle}>动态缩放元素</div>
      <button 
        className={buttonClasses}
        onClick={() => setIsActive(!isActive)}
      >
        {isActive ? '激活中' : '未激活'}
      </button>
    </div>
  );
}

最佳实践建议:

  1. 组件级样式 → 首选 CSS Modules 或 CSS-in-JS
  2. 全局主题/基础样式 → 使用外部样式表
  3. 简单动态样式 → 内联样式或动态类名
  4. 复杂交互/主题 → CSS-in-JS 解决方案

常见问题解决:

类名冲突 → 使用 CSS Modules 自动生成唯一类名
伪类/媒体查询 → 避免用内联样式(使用 CSS/CSS-in-JS)
全局样式污染 → 为根元素添加命名空间
动态主题切换 → 考虑使用 CSS 变量或 ThemeProvider (CSS-in-JS)

根据项目规模和团队偏好选择合适的方式,中小型项目推荐 CSS Modules + 少量内联样式,大型项目可考虑 CSS-in-JS 方案。

相关推荐
lichenyang45313 分钟前
把 demo 里的 console.log 全换成 HiLog:从 %{private} 没脱敏的困惑说起
前端
光影少年17 分钟前
组件复用:HOC、Render Props、自定义Hook 对比
前端·react.js·掘金·金石计划
Gauss松鼠会21 分钟前
【GaussDB】GaussDB SMP特性调优详解
java·服务器·前端·数据库·sql·算法·gaussdb
葬送的代码人生26 分钟前
JavaScript 数组完全指南:从入门到实战
前端·javascript·算法
用户9385156350728 分钟前
深入理解 JavaScript 同步与异步:从单线程到事件循环与 Promise
前端·javascript
搬砖的码农28 分钟前
造一个 Agent 运行时 #01:我决定开干,顺便把坑都写下来
前端·agent·ai编程
yingyima31 分钟前
深入解析:定时任务失败重试机制的底层原理与实践
前端
哈撒Ki32 分钟前
快速入门vue3与常见面试题
前端·vue.js·面试
踩着两条虫36 分钟前
VTJ.PRO v2.4.2 私有化部署与升级实操指南
前端·人工智能·低代码·架构·数据挖掘
木斯佳41 分钟前
前端八股文面经大全:美团前端暑期实习一面(2026-06-08)·面经深度解析
前端