react-13react中外部css引入以及style内联样式(动态className与动态style)

1. 外部css文件 - 普通引入

1.1 创建一个 CSS 文件,MyComponent.css。
css 复制代码
/* MyComponent.css */
.my-class {
  color: red;
  font-size: 20px;
}
1.2 组件中import引入
javascript 复制代码
import React from 'react';
import './MyComponent.css'; // 引入 CSS 文件

function MyComponent() {
  return (
    <div className="my-class">
      This is a div with a class name.
    </div>
  );
}

export default MyComponent;
1.3 动态className
javascript 复制代码
import React, { useState } from 'react';

function MyComponent() {
  const [isActive, setIsActive] = useState(false);

  return (
    <div 
      className={isActive ? 'active' : 'inactive'}
      onClick={() => setIsActive(!isActive)}
    >
      Click me to toggle class.
    </div>
  );
}

export default MyComponent;

2. 外部css文件 - CSS Modules引入

CSS Modules 是一种用于在 JavaScript 生态系统中使用 CSS 的方法,它通过模块化的方式避免 CSS 类名冲突。

2.1 创建一个 CSS Module 文件,MyComponent.module.css。
css 复制代码
/* MyComponent.module.css */
.myClass {
  color: red;
  font-size: 20px;
}
2.2 在组件中引入并使用 CSS Module
javascript 复制代码
import React from 'react';
import styles from './MyComponent.module.css'; // 引入 CSS Module 文件

function MyComponent() {
  return (
    <div className={styles.myClass}>
      This is a div with a CSS Module class name.
    </div>
  );
}

export default MyComponent;

3. style内联样式引入

3.1 style内联样式
javascript 复制代码
import React from 'react';

function MyComponent() {
  return (
    <div style={{ color: 'blue', fontSize: '20px' }}>
      This is a div with inline style.
    </div>
  );
}

export default MyComponent;
3.2 动态style

鼠标移入移出背景颜色的变化

javascript 复制代码
 state = {
    isHover: false
  }
  // 鼠标移入移出判断
  handleMouse = (isEnter) => {
    return () => {
      this.setState({ isHover: isEnter })
    }
  }

  render() {
    return (
      <div>
        {/* 判断鼠标移入移出 */}
        <li style={{ backgroundColor: this.state.isHover? '#f5f5f5' : '#fff' }}     
        onMouseEnter={this.handleMouse(true)} onMouseLeave={this.handleMouse(false)} >
      </div>
    )}
相关推荐
Filotimo_20 小时前
2.CSS3.(3).html
前端·css3
whyfail20 小时前
React v19.2版本
前端·javascript·react.js
慧慧吖@20 小时前
react基础
前端·javascript·react.js
浪裡遊21 小时前
MUI组件库与主题系统全面指南
开发语言·前端·javascript·vue.js·react.js·前端框架·node.js
DiXinWang21 小时前
关闭谷歌浏览器提示“若要接收后续 Google Chrome 更新,您需使用 Windows 10 或更高版本”的方法
前端·chrome
CoderYanger21 小时前
前端基础——HTML练习项目:填写简历信息
前端·css·职场和发展·html
muyouking1121 小时前
深入理解 HTML `<label>` 的 `for` 属性:提升表单可访问性与用户体验
前端·html·ux
软件技术NINI21 小时前
html css js网页制作成品——饮料官网html+css+js 4页网页设计(4页)附源码
javascript·css·html
软件技术NINI21 小时前
html css js网页制作成品——HTML+CSS辣条俱乐部网页设计(5页)附源码
javascript·css·html
IT_陈寒1 天前
Java性能调优:从GC日志分析到实战优化的5个关键技巧,让你的应用快如闪电!
前端·人工智能·后端