在React里面的多种使用CSS的方法

简介: 在React里面的多种使用CSS的方法

我们都熟悉将样式表链接到HTML文档 <head> 的标准方法,这只是我们编写CSS的几种方法之一。但是在单页应用程序 (SPA) 中设置样式是什么样子的,比如 React ?

事实证明有很多种办法,有些办法和传统的类似,则有些办法是React的个例。

导入外部样式表

顾名思义,React 可以导入 CSS 文件。这个过程类似于我们在HTML <head> 中链接CSS文件的方式

  1. 在项目目录中创建一个新的 CSS 文件。
  2. 编写 CSS。
  3. 导入到 React 文件中。
import "./style.css";

这种导入方式一般都在文件最顶端。

import { React } from "react";  
import "./Components/css/App.css";  
function App() {  
  return (  
    <div className="main">  
    </div>  
  );  
}  
export default App;

在上面代码里,将 CSS 文件导入到 App.js /Components/css 文件夹中。

编写内联样式

看到这个方式,你肯定会提到 “内联样式不方便维护”等之类的话。但在React里,我感觉可维护性不是个问题。
这是 React 中内联样式的一个超级简单的例子:

<div className="main" style={
  {color:"red"}}>

但是我觉得更好的一个方法是创建对象,统一管理。

import { React } from "react";  
function App() {  
  const styles = {  
    main: {  
      backgroundColor: "#f1f1f1",  
      width: "100%",  
    },  
    inputText: {  
      padding: "10px",  
      color: "red",  
    },  
  };  
  return (  
    <div className="main" style={styles.main}>  
      <input type="text" style={styles.inputText}></input>  
    </div>  
  );  
}  
export default App;

使用 CSS 模块

CSS Modules
CSS 模块...它们具有局部范围变量的优点,可以与 React 一起使用。但是,它们到底是什么?

引用官方文档:

CSS Modules works by compiling individual CSS files into both CSS and data. The CSS output is normal, global CSS, which can be injected directly into the browser or concatenated together and written to a file for production use. The data is used to map the human-readable names you’ve used in the files to the globally-safe output CSS.
CSS 模块的工作原理是将单个 CSS 文件编译为 CSS 和数据。CSS输出是正常的全局CSS,可以直接注入浏览器或连接在一起并写入文件以供生产使用。数据用于将您在文件中使用的人类可读名称映射到全局安全的输出 CSS。

简单来说,CSS 模块允许我们在多个文件中使用相同的类名而不会发生冲突,因为每个类名都被赋予了唯一的编程名称。这在较大的应用程序中特别有用。每个类名的范围都在本地限定为要在其中导入它的特定组件。

CSS 模块样式表类似于常规样式表,只是扩展名不同(例如 styles.module.css )。以下是它们的设置方式:

  1. 创建一个扩展名的文件 .module.css
  2. 将该模块导入 React 应用程序(如我们之前看到的)
  3. 向元素或组件添加 , className 并从导入的样式中引用特定样式。
/* styles.module.css */  
.font {  
  color: #f00;  
  font-size: 20px;  
}  

import { React } from "react";  
import styles from "./styles.module.css";  
function App() {  
  return (  
    <h1 className={styles.heading}>Hello World</h1>  
  );  
}  
export default App;

使用样式化组件

样式化组件?它可以在JavaScript中使用实际CSS构建自定义组件。样式化组件基本上是一个 React 组件,具有单独样式。一些功能包括唯一的类名,动态样式和更好的CSS管理,因为每个组件都有自己单独的样式。

在命令行中安装样式化的组件 npm 包:

npm install styled-components

导入 React 应用程序:

import styled from 'styled-components'

创建组件并为其指定样式属性。请注意在 Wrapper 对象中使用由反引号表示的模板文本:

import { React } from "react";  
import styled from "styled-components";  
function App() {  
  const Wrapper = styled.div`  
    width: 100%;  
    height: 100px;  
    background-color: red;  
    display: block;  
  `;  
  return <Wrapper />;  
}  
export default App;

本文同步我的技术文档

相关文章
|
2月前
|
前端开发
create-react-app 如何使用 less/sass 和 react-css-modules?
本文详细介绍了在 create-react-app 项目中如何使用 less/sass 和 react-css-modules 来管理和应用样式。首先,通过安装相应依赖并配置 webpack 支持 less/sass;接着,介绍如何使用这些预处理器编写样式;最后,讲解了如何配置和使用 react-css-modules 实现样式的模块化管理,以及如何结合使用 less/sass 和 react-css-modules 提高开发效率和代码质量。
44 3
|
2月前
|
缓存 监控 前端开发
CSS 提高性能的方法
【10月更文挑战第24天】在实际应用中,还需要根据具体项目的特点和需求,灵活选择和组合这些方法,不断进行优化和改进。同时,随着技术的不断发展,也需要持续关注新的性能优化技巧和最佳实践,以保持在性能优化方面的领先地位。你对 CSS 性能优化还有哪些深入的思考和经验呢?欢迎进一步交流和分享。
|
2月前
|
前端开发
css页面顶部底部固定,中间自适应几种方法
【10月更文挑战第22天】css页面顶部底部固定,中间自适应几种方法
|
3月前
|
前端开发 JavaScript
React Tailwind CSS
10月更文挑战第12天
25 1
|
3月前
|
前端开发
|
3月前
|
Android开发
jmessage-react-plugin的正确引入方法
jmessage-react-plugin的正确引入方法
23 1
|
3月前
|
前端开发 容器
CSS 中几种常用的换行方法
CSS 中几种常用的换行方法
39 1
|
3月前
|
前端开发 容器
React 使用 CSS 样式
10月更文挑战第12天
44 0
|
3月前
|
前端开发 UED
css性能优化的方法
css性能优化的方法
36 0
|
2月前
|
前端开发 JavaScript 开发者
颠覆传统:React框架如何引领前端开发的革命性变革
【10月更文挑战第32天】本文以问答形式探讨了React框架的特性和应用。React是一款由Facebook推出的JavaScript库,以其虚拟DOM机制和组件化设计,成为构建高性能单页面应用的理想选择。文章介绍了如何开始一个React项目、组件化思想的体现、性能优化方法、表单处理及路由实现等内容,帮助开发者更好地理解和使用React。
91 9