返回顶部
首页 > 资讯 > 前端开发 > 其他 >react 怎么动态修改style
  • 350
分享到

react 怎么动态修改style

styleReact 2023-05-14 21:05:33 350人浏览 独家记忆
摘要

本教程操作环境:windows10系统、React18.0.0版、Dell G3电脑。react 怎么动态修改style?关于React动态修改元素样式的三种方式React动态修改元素样式React动态修改元素样式常用的方式有两种:借助re

react 怎么动态修改style

教程操作环境:windows10系统、React18.0.0版、Dell G3电脑。

react 怎么动态修改style?

关于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中判断的,如下:

5ac6a18523a6456a57897685a33a437.jpg

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

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

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

057eff8accc126dcf8412d8d1872efe.jpg

小结一下:

  • 如果改变的样式比较多而杂使用 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-基本使用

步骤

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

2.引入使用。

import styles from './index.module.scss'
<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}>
      {}
        <h1 className="title">
          <span className="text">登录</span>  
          <span>登录</span>  
      </h1>
            <form className="login-form"></form>
    </div>
  )
}

以上就是react 怎么动态修改style的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: react 怎么动态修改style

本文链接: https://lsjlt.com/news/206229.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
热门wiki
近期文章
推荐阅读
热门问答
热门标签
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作