说说react中引入css的方式有哪几种?区别?

简介: 说说react中引入css的方式有哪几种?区别?

组件式开发选择合适的css解决方案尤为重要

通常会遵循以下规则:

可以编写局部css,不会随意污染其他组件内的原生;

可以编写动态的css,可以获取当前组件的一些状态,根据状态的变化生成不同的css样式;

支持所有的css特性:伪类、动画、媒体查询等;

编写起来简洁方便、最好符合一贯的css风格特点

在这一方面,vue使用css起来更为简洁:

通过 style 标签编写样式

scoped 属性决定编写的样式是否局部有效

lang 属性设置预处理器

内联样式风格的方式来根据最新状态设置和改变css

而在react中,引入CSS就不如Vue方便简洁,其引入css的方式有很多种,各有利弊

二、方式

常见的CSS引入方式有以下:

**

  1. 在组件内直接使用
在组件内直接使用
直接在组件中书写css样式,通过style属性直接引入**
上面可以看到,css属性需要转换成驼峰写法
这种方式优点:
内联样式, 样式之间不会有冲突
可以动态获取当前state中的状态
缺点:
写法上都需要使用驼峰标识
某些样式没有提示
大量的样式, 代码混乱
某些样式无法编写(比如伪类/伪元素)
  1. 组件中引入 .css 文件
这种方式存在不好的地方在于样式是全局生效,样式之间会互相影响
• 1
  1. 组件中引入 .module.css 文件
将css文件作为一个模块引入,这个模块中的所有css,只作用于当前组件。
  不会影响当前组件的后代组件
  这种方式是webpack特工的方案,只需要配置webpack配置文件中modules:true即可
  这种方式能够解决局部作用域问题,但也有一定的缺陷:
引用的类名,不能使用连接符(.xxx-xx),在 JavaScript 中是不识别的
所有的 className 都必须使用 {style.className} 的形式来编写
不方便动态来修改某些样式,依然需要使用内联样式的方式;
  1. CSS in JS
CSS-in-JS, 是指一种模式,其中CSS由 JavaScript生成而不是在外部文件中定义
此功能并不是 React 的一部分,而是由第三方库提供,例如: 
styled-components
emotion
glamorous
下面主要看看styled-components的基本使用
本质是通过函数的调用,最终创建出一个组件:
这个组件会被自动添加上一个不重复的class
styled-components会给该class添加相关的样式.

三、区别

通过上面四种样式的引入,可以看到:

在组件内直接使用css该方式编写方便,容易能够根据状态修改样式属性,但是大量的演示编写容易导致代码混乱

组件中引入 .css 文件符合我们日常的编写习惯,但是作用域是全局的,样式之间会层叠

引入.module.css 文件能够解决局部作用域问题,但是不方便动态修改样式,需要使用内联的方式进行样式的编写

通过css in js 这种方法,可以满足大部分场景的应用,可以类似于预处理器一样样式嵌套、定义、修改状态等


相关文章
|
2月前
|
JavaScript 前端开发 开发者
React和Vue有什么区别?
React 和 Vue 都有各自的优势和特点,开发者可以根据项目的需求、团队的技术背景以及个人的喜好来选择使用。无论是 React 还是 Vue,它们都在不断发展和完善,为前端开发提供了强大的支持。
118 2
|
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 提高开发效率和代码质量。
41 3
|
2月前
|
JavaScript 前端开发 算法
React 框架和 Vue 框架的区别是什么?
React框架和Vue框架都是目前非常流行的前端JavaScript框架,它们在很多方面存在区别
|
2月前
|
前端开发 Ruby
CSS 预编语言的区别
【10月更文挑战第24天】Sass、Less 和 Stylus 等 CSS 预编语言在语法特点、功能特性、性能表现、社区和生态系统等方面存在着不同之处。在选择使用哪种预编语言时,需要综合考虑项目需求、团队技术偏好、个人习惯等因素。你可以根据具体情况进行评估和选择,以充分发挥这些语言的优势,提高前端开发的效率和质量。
|
2月前
|
前端开发 开发者 UED
设备像素、css像素、设备独立像素、dpr、ppi之间的区别
【10月更文挑战第24天】在实际应用中,这些概念相互关联,共同影响着网页在不同设备上的显示表现。开发者需要了解它们之间的区别和关系,以便更好地进行网页设计和优化,确保在各种设备上都能提供良好的用户体验。
|
2月前
|
JavaScript 前端开发 算法
在性能上,React和Vue有什么区别
【10月更文挑战第23天】在性能上,React和Vue有什么区别
22 1
|
3月前
|
前端开发 JavaScript UED
react-router 里的 Link 标签和 a 标签有什么区别
`react-router` 中的 `Link` 标签与 HTML 中的 `a` 标签的主要区别在于:`Link` 是专门为 React 应用设计的,用于实现客户端路由导航,不会触发页面的重新加载,而 `a` 标签则会刷新整个页面。使用 `Link` 可以提升应用的性能和用户体验。
|
3月前
|
前端开发 开发者 UED
React 18 与之前版本的主要区别
【10月更文挑战第12天】 总的来说,React 18 的这些区别体现了 React 团队对于提升应用性能、用户体验和开发效率的持续努力。开发者需要适应这些变化,充分利用新特性来构建更出色的应用。同时,随着技术的不断发展,React 也将继续演进,为开发者带来更多的创新和便利。
|
3月前
|
前端开发 JavaScript
React Tailwind CSS
10月更文挑战第12天
25 1
|
2月前
|
开发框架 JavaScript 前端开发
React和Vue之间的区别是什么
【10月更文挑战第23天】React和Vue之间的区别是什么
18 0