我的编程空间,编程开发者的网络收藏夹
学习永远不晚

react如何动态修改style

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

react如何动态修改style

这篇文章主要介绍“react如何动态修改style”,在日常操作中,相信很多人在react如何动态修改style问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react如何动态修改style”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

react动态修改style的方法:1、在需要修改样式的元素上添加ref,其语法如“<div className='scroll-title clear-fix' ref={ this.manage }>”;2、通过动态控制状态的变化修改元素的样式;3、通过在DOM中使用JS代码实现不同DOM的展示与隐藏转换。

关于React动态修改元素样式的三种方式

React动态修改元素样式

React动态修改元素样式常用的方式有两种:借助ref和通过动态控制状态的变化修改元素的样式

1.借助ref动态修改样式

在需要修改样式的元素上添加ref

<div className='scroll-title clear-fix' ref={ this.manage }>

在constructor中添加React.createRef()

this.manage = React.createRef()

在逻辑代码中使用

this.manage.current.style.display = 'block'

如果代码中识别不出this的话需要通过let that = this 改变this的指向

that.manage.current.style.display = 'block'

2.通过动态控制状态的变化修改元素的样式(两种方式)

方式一

逻辑代码中设置一个标志位display默认为true,通过对应的条件改变display的值为true或者false,进而将对应的样式名赋值给DOM的className属性,样式写在对应的style当中

例如:

 constructor() {
       super()
       this.state = {
           display: true
       }
   }  
   componentDidMount() {
       window.onscroll = function(event) {
               if (divTop < -12) {
                    that.setState({
                        display: false
                    })
                   that.manage.current.style.display = 'block'
               } else {
                    that.setState({
                        display: true
                    })
               }
       }
   }
<div className={this.state.display ? 'none' : 'scroll-title }>

方式二

方式二和方式一实现的原理是一样的,逻辑代码中设置一个标志位display默认为true,通过对应的条件改变display的值为true或者false,进而将对应的样式名赋值给DOM的className属性,样式写在对应的style当中,不同之处在于逻辑代码的判断不是在DOM中,而是在js中判断的,如下:

react如何动态修改style

3.通过在DOM中使用JS代码(三元运算符)

实现不同DOM的展示与隐藏转换

方式三并不是严格意义上的改变样式,只是用来改变显示与隐藏及展示对应的组件的

react如何动态修改style

小结一下:

  • 如果改变的样式比较多而杂使用 2

  • 如果改变的样式不太多使用 1和2

  • 如果仅仅是两个组件的切换(显示与隐藏)使用 3最方便

React样式冲突问题

在react脚手架中已经有了sass的配置,因此只需要安装sass的依赖包,就可以直接使用sass了

安装sass依赖包

npm i sass -D

- 把index.css改成index.scss

- 导入index.scss文件

注意:如果使用了scss,scss中使用图片的绝对路径的时候需要加上~

background-image: url(~assets/login.png);

css-样式私有化

css modules-基本使用

步骤

改样式文件名。从 xx.scss -> xx.module.scss (React脚手架中的约定,与普通 CSS 作区分)

引入使用。

  • 组件中导入该样式文件(注意语法)

import styles from './index.module.scss'
  • 通过 styles 对象访问对象中的样式名来设置样式

<div className={styles.css类名}></div>

css类名是index.module.scss中定义的类名。

示例

定义样式 index.module.css

.root {font-size: 100px;}

使用样式

import styles from './index.module.css'
<div className={styles.root}>div的内容</div>

原理

CSS Modules 通过自动给 CSS 类名补足类名,保证类名的唯一性,从而避免样式冲突的问题

css module的注意点

类名最好使用驼峰命名,因为最终类名会生成styles的一个属性

cssModules-维持类名

格式

在xxx.module.scss中,如果希望维持类名,可以使用格式:

:global(.类名)


:global(.a) {   }


.aa :golbal(.a) { }

覆盖第三方组件的样式

:global(.ant-btn) {
 color: red !important;
}

css modules-最佳实践

- 每个组件的根节点使用 CSSModules 形式的类名( 根元素的类名: root )

- 其他所有的子节点,都使用普通的 CSS 类名 :global

index.module.scss中

// index.module.scss
.root {
 display: 'block';
 position: 'absolute';
 // 此处,使用 global 包裹其他子节点的类名。此时,这些类名就不会被处理,在 JSX 中使用时,就可以用字符串形式的类名
 // 如果不加 :global ,所有类名就必须添加 styles.title 才可以
 :global {
   .title {
     .text {
     }
     span {
     }
   }
   .login-form { ... }
 }
}

组件使用

import styles from './index.module.scss'
const 组件 = () => {
 return (
   {}
     <div className={styles.root}>
     {}
       <h2 className="title">
         <span className="text">登录</span>  
         <span>登录</span>  
     </h2>
           <form className="login-form"></form>
   </div>
 )
}

到此,关于“react如何动态修改style”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

react如何动态修改style

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

react如何动态修改style

这篇文章主要介绍“react如何动态修改style”,在日常操作中,相信很多人在react如何动态修改style问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react如何动态修改style”的疑惑有所帮助!
2023-07-04

react 怎么动态修改style

react动态修改style的方法:1、在需要修改样式的元素上添加ref,其语法如“<div className='scroll-title clear-fix' ref={ this.manage }>”;2、通过动态控制状态的变化修改元素的样式;3、通过在DOM中使用JS代码实现不同DOM的展示与隐藏转换。
2023-05-14

javascript如何修改style样式

小编给大家分享一下javascript如何修改style样式,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!JavaScript是什么JavaScript是一种直译
2023-06-14

SpringBoot如何动态修改Scheduled

这篇文章主要介绍“SpringBoot如何动态修改Scheduled”,在日常操作中,相信很多人在SpringBoot如何动态修改Scheduled问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SpringB
2023-07-06

vue如何动态设置class、动态设置style

这篇文章主要介绍了vue如何动态设置class、动态设置style,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

react如何修改值

今天小编给大家分享一下react如何修改值的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。react修改值的方法:1、打开相应
2023-07-04

react如何修改端口

这篇“react如何修改端口”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“react如何修改端口”文章吧。react修改端口
2023-07-04

react refs如何修改dom

今天小编给大家分享一下react refs如何修改dom的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。react refs修
2023-07-04

react如何设置style属性

这篇文章主要讲解了“react如何设置style属性”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react如何设置style属性”吧!react设置style属性的方法:1、通过“
2023-07-05

react如何改变组件状态

这篇文章主要介绍“react如何改变组件状态”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“react如何改变组件状态”文章能帮助大家解决问题。在react中,可以利用setState()来修改组件的
2023-07-04

react如何改变列表状态

本篇内容介绍了“react如何改变列表状态”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!react改变列表状态的方法:1、打开相应的reac
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录