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

目錄
React動(dòng)態(tài)修改元素樣式
1.借助ref動(dòng)態(tài)修改樣式
2.透過動(dòng)態(tài)控制狀態(tài)的變化修改元素的樣式(兩種方式)
React樣式衝突問題
css-樣式私有化
cssModules-維持類別名稱?
css modules-最佳實(shí)務(wù)
首頁 web前端 前端問答 react 怎麼動(dòng)態(tài)修改style

react 怎麼動(dòng)態(tài)修改style

Dec 28, 2022 am 10:44 AM
react style

react動(dòng)態(tài)修改style的方法:1、在需要修改樣式的元素上新增ref,其語法如「

react 怎麼動(dòng)態(tài)修改style

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

react 怎麼動(dòng)態(tài)修改style?

關(guān)於React動(dòng)態(tài)修改元素樣式的三種方式

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

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

1.借助ref動(dòng)態(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;

#如果程式碼中辨識(shí)不出this的話需要透過let that = this 改變this的指向

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

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

方式一

邏輯程式碼中設(shè)定一個(gè)標(biāo)誌位display預(yù)設(shè)為true,透過對(duì)應(yīng)的條件改變display的值為true或false,進(jìn)而將對(duì)應(yīng)的樣式名稱賦值給DOM的className屬性,樣式寫在對(duì)應(yīng)的style當(dāng)中

例如:

 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 }>

方式二

#方式二和方式一實(shí)現(xiàn)的原理是一樣的,邏輯程式碼中設(shè)定一個(gè)標(biāo)誌位display預(yù)設(shè)為true,透過對(duì)應(yīng)的條件改變display的值為true或false,進(jìn)而將對(duì)應(yīng)的樣式名稱賦值為DOM的className屬性,樣式寫在對(duì)應(yīng)的style當(dāng)中,不同之處在於邏輯程式碼的判斷不是在DOM中,而是在js中判斷的,如??下:

react 怎麼動(dòng)態(tài)修改style

3.透過在DOM中使用JS程式碼(三元運(yùn)算子)

#實(shí)現(xiàn)不同DOM的展示與隱藏轉(zhuǎn)換

方式三不是嚴(yán)格意義上的改變樣式,只是用來改變顯示與隱藏及展示對(duì)應(yīng)的元件的

react 怎麼動(dòng)態(tài)修改style

小結(jié)一下:

  • #如果改變的樣式比較多而雜使用2
  • 如果改變的樣式不太多使用1和2
  • 如果只是兩個(gè)元件的切換(顯示與隱藏)使用3最方便

React樣式衝突問題

在react腳手架中已經(jīng)有了sass的配置,因此只需要安裝sass的依賴包,就可以直接使用sass了

安裝sass依賴套件

npm i sass -D

- 把index.css改成index.scss

- 導(dǎo)入index. scss檔案

注意:如果使用了scss,scss中使用圖片的絕對(duì)路徑的時(shí)候需要加上~?

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 物件存取物件中的樣式名稱來設(shè)定樣式
<div className={styles.css類名}></div>

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

範(fàn)例

定義樣式index.module.css?

.root {font-size: 100px;}

#使用樣式

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

原理

#CSS Modules 透過自動(dòng)給予CSS 類別名稱補(bǔ)足類別名,確保類別名稱的唯一性,從而避免樣式衝突的問題??

css module的注意點(diǎn)?

類別名稱最好使用駝峰命名,因?yàn)樽罱K類別名稱會(huì)產(chǎn)生styles的一個(gè)屬性

cssModules-維持類別名稱?

格式

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

:global(.類別名稱)

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

覆蓋第三方元件的樣式

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

css modules-最佳實(shí)務(wù)

#- 每個(gè)元件的根節(jié)點(diǎn)使用CSSModules 形式的類別名稱( 根元素的類別名稱: root )

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

index.module.scss中

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

元件使用

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

登錄 登錄

) }

推薦學(xué)習(xí):《react影片教學(xué)

以上是react 怎麼動(dòng)態(tài)修改style的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

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

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

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

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

React Router使用指南:如何實(shí)現(xiàn)前端路由控制 React Router使用指南:如何實(shí)現(xiàn)前端路由控制 Sep 29, 2023 pm 05:45 PM

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

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

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯(lián)網(wǎng)技術(shù)的不斷發(fā)展,前端框架在Web開發(fā)中起著至關(guān)重要的作用。 PHP、Vue和React作為三種代表性的前端框架,每一種都具有其獨(dú)特的特徵和優(yōu)勢(shì)。在選擇使用哪種前端框架時(shí),開發(fā)人員需要根據(jù)專案需求、團(tuán)隊(duì)技能和個(gè)人偏好做出明智的決策。本文將透過比較PHP、Vue和React這三種前端框架的特徵和使

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

Java框架與React框架的整合:步驟:設(shè)定後端Java框架。建立專案結(jié)構(gòu)。配置建置工具。建立React應(yīng)用程式。編寫RESTAPI端點(diǎn)。配置通訊機(jī)制。實(shí)戰(zhàn)案例(SpringBoot+React):Java程式碼:定義RESTfulAPI控制器。 React程式碼:取得並顯示API回傳的資料。

vue.js vs.反應(yīng):特定於項(xiàng)目的考慮因素 vue.js vs.反應(yīng):特定於項(xiàng)目的考慮因素 Apr 09, 2025 am 12:01 AM

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

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

NetflixusesAcustomFrameworkcalled“ Gibbon” BuiltonReact,notReactorVuedIrectly.1)TeamSperience:selectBasedonFamiliarity.2)ProjectComplexity:vueforsimplerprojects:reactforforforproproject,reactforforforcompleplexones.3)cocatizationneedneeds:reactoffipicatizationneedneedneedneedneedneeds:reactoffersizationneedneedneedneedneeds:reactoffersizatization needefersmoreflexibleise.4)

React在HTML中的作用:增強(qiáng)用戶體驗(yàn) React在HTML中的作用:增強(qiáng)用戶體驗(yàn) Apr 09, 2025 am 12:11 AM

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

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

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

See all articles