国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
React動態(tài)修改元素樣式
1.借助ref動態(tài)修改樣式
2.通過動態(tài)控制狀態(tài)的變化修改元素的樣式(兩種方式)
React樣式沖突問題
css-樣式私有化
cssModules-維持類名 
css modules-最佳實踐
首頁 web前端 前端問答 react 怎么動態(tài)修改style

react 怎么動態(tài)修改style

Dec 28, 2022 am 10:44 AM
react style

react動態(tài)修改style的方法:1、在需要修改樣式的元素上添加ref,其語法如“<div className=&#39;scroll-title clear-fix&#39; ref={ this.manage }>”;2、通過動態(tài)控制狀態(tài)的變化修改元素的樣式;3、通過在DOM中使用JS代碼實現不同DOM的展示與隱藏轉換。

react 怎么動態(tài)修改style

本教程操作環(huán)境:Windows10系統(tǒng)、react18.0.0版、Dell G3電腦。

react 怎么動態(tài)修改style?

關于React動態(tài)修改元素樣式的三種方式

React動態(tài)修改元素樣式

React動態(tài)修改元素樣式常用的方式有兩種:借助ref和通過動態(tài)控制狀態(tài)的變化修改元素的樣式

1.借助ref動態(tài)修改樣式

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

<div className=&#39;scroll-title clear-fix&#39; ref={ this.manage }>

在constructor中添加React.createRef()

this.manage = React.createRef()

在邏輯代碼中使用

this.manage.current.style.display = &#39;block&#39;

如果代碼中識別不出this的話需要通過let that = this 改變this的指向

that.manage.current.style.display = &#39;block&#39;

2.通過動態(tài)控制狀態(tài)的變化修改元素的樣式(兩種方式)

方式一

邏輯代碼中設置一個標志位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 = &#39;block&#39;
                } else {
                     that.setState({
                         display: true
                     })
                }
        }
    }
<div className={this.state.display ? &#39;none&#39; : &#39;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 作區(qū)分)

2.引入使用。

  • 組件中導入該樣式文件(注意語法)
import styles from &#39;./index.module.scss&#39;
  • 通過 styles 對象訪問對象中的樣式名來設置樣式
<div className={styles.css類名}></div>

css類名是index.module.scss中定義的類名。

示例

定義樣式 index.module.css

.root {font-size: 100px;}

使用樣式

import styles from &#39;./index.module.css&#39;
<div className={styles.root}>div的內容</div>

原理

CSS Modules 通過自動給 CSS 類名補足類名,保證類名的唯一性,從而避免樣式沖突的問題

css module的注意點

類名最好使用駝峰命名,因為最終類名會生成styles的一個屬性

cssModules-維持類名

格式

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

:global(.類名)

/*這樣css modules就不會修改掉類名.a了。等價于寫在 index.css中 */
:global(.a) {   }
 
/* 這樣css modules就不會修改掉類名.a了, 但是 .aa還是會被修改 */
.aa :golbal(.a) { }

覆蓋第三方組件的樣式

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

css modules-最佳實踐

- 每個組件的根節(jié)點使用 CSSModules 形式的類名( 根元素的類名: root )

- 其他所有的子節(jié)點,都使用普通的 CSS 類名 :global

index.module.scss中

// index.module.scss
.root {
  display: &#39;block&#39;;
  position: &#39;absolute&#39;;
  // 此處,使用 global 包裹其他子節(jié)點的類名。此時,這些類名就不會被處理,在 JSX 中使用時,就可以用字符串形式的類名
  // 如果不加 :global ,所有類名就必須添加 styles.title 才可以
  :global {
    .title {
      .text {
      }
      span {
      }
    }
    .login-form { ... }
  }
}

組件使用

import styles from &#39;./index.module.scss&#39;
const 組件 = () => {
  return (
    {/* (1) 根節(jié)點使用 CSSModules 形式的類名( 根元素的類名: `root` )*/}
      
{/* (2) 所有子節(jié)點,都使用普通的 CSS 類名*/}

登錄 登錄

) }

推薦學習:《react視頻教程

以上是react 怎么動態(tài)修改style的詳細內容。更多信息請關注PHP中文網其他相關文章!

本站聲明
本文內容由網友自發(fā)貢獻,版權歸原作者所有,本站不承擔相應法律責任。如您發(fā)現有涉嫌抄襲侵權的內容,請聯系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅動的應用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

element.style怎么修改 element.style怎么修改 Nov 24, 2023 am 11:15 AM

element.style修改元素的方法:1、修改元素的背景顏色;2、修改元素的字體大??;3、修改元素的邊框樣式;4、修改元素的字體樣式;5、修改元素的水平對齊方式。詳細介紹:1、修改元素的背景顏色,其語法為“document.getElementById("myElement").style.backgroundColor = "red";”;2、修改元素的字體大小等等。

React Router使用指南:如何實現前端路由控制 React Router使用指南:如何實現前端路由控制 Sep 29, 2023 pm 05:45 PM

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。ReactRouter作為React生態(tài)系統(tǒng)中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實現變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,并提供一些具體的代碼示例。安裝ReactRouter首先,我們需

PHP、Vue和React:如何選擇最適合的前端框架? PHP、Vue和React:如何選擇最適合的前端框架? Mar 15, 2024 pm 05:48 PM

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯網技術的不斷發(fā)展,前端框架在Web開發(fā)中起著至關重要的作用。PHP、Vue和React作為三種具有代表性的前端框架,每一種都具有其獨特的特點和優(yōu)勢。在選擇使用哪種前端框架時,開發(fā)人員需要根據項目需求、團隊技能和個人偏好做出明智的決策。本文將通過比較PHP、Vue和React這三種前端框架的特點和使

Java框架與前端React框架的整合 Java框架與前端React框架的整合 Jun 01, 2024 pm 03:16 PM

Java框架與React框架的整合:步驟:設置后端Java框架。創(chuàng)建項目結構。配置構建工具。創(chuàng)建React應用。編寫RESTAPI端點。配置通信機制。實戰(zhàn)案例(SpringBoot+React):Java代碼:定義RESTfulAPI控制器。React代碼:獲取并顯示API返回的數據。

vue.js vs.反應:特定于項目的考慮因素 vue.js vs.反應:特定于項目的考慮因素 Apr 09, 2025 am 12:01 AM

Vue.js適合中小型項目和快速迭代,React適用于大型復雜應用。1)Vue.js易于上手,適用于團隊經驗不足或項目規(guī)模較小的情況。2)React的生態(tài)系統(tǒng)更豐富,適合有高性能需求和復雜功能需求的項目。

React與Vue:Netflix使用哪個框架? React與Vue:Netflix使用哪個框架? Apr 14, 2025 am 12:19 AM

NetflixusesAcustomFrameworkcalled“ Gibbon” BuiltonReact,notReactorVueDirectly.1)TeamExperience:selectBasedAsedonFamiliarity.2)ProjectComplexity:vueforsimplerprojects,vueforsimplerprojects,reactforforforecomplexones.3)cocatizationNeedsneeds:reactofficatizationneedneeds:reactofferizationneedneedneedneeds:reactoffersizatization needeffersefersmoreflexiblesimore.4)ecosyaka

React在HTML中的作用:增強用戶體驗 React在HTML中的作用:增強用戶體驗 Apr 09, 2025 am 12:11 AM

React通過JSX與HTML結合,提升用戶體驗。1)JSX嵌入HTML,使開發(fā)更直觀。2)虛擬DOM機制優(yōu)化性能,減少DOM操作。3)組件化管理UI,提高可維護性。4)狀態(tài)管理和事件處理增強交互性。

React的生態(tài)系統(tǒng):庫,工具和最佳實踐 React的生態(tài)系統(tǒng):庫,工具和最佳實踐 Apr 18, 2025 am 12:23 AM

React生態(tài)系統(tǒng)包括狀態(tài)管理庫(如Redux)、路由庫(如ReactRouter)、UI組件庫(如Material-UI)、測試工具(如Jest)和構建工具(如Webpack)。這些工具協(xié)同工作,幫助開發(fā)者高效開發(fā)和維護應用,提高代碼質量和開發(fā)效率。

See all articles