文章詳情頁(yè)
javascript - react如何不通過state去修改classname?
瀏覽:88日期:2023-02-13 17:49:59
問題描述
如題,react中怎么樣可以不用下面這種方式去改變class,直接用原生js去改變class?
<p className={ this.state.*** ? class1 : class2 }></p>
問題解答
回答1:<p ref={(p)=>{this.getDom = p}}></p>...// 可以在一個(gè)事件中通過this.getDom獲取當(dāng)前元素,再通過className設(shè)置this.getDom.className = class1回答2:
原生 JS 操作 DOM 的行為是不推薦的,如果非常需要這個(gè)能力,可以通過 ReactDOM 的 findDOMNode 方法去獲取到 DOM 節(jié)點(diǎn)的引用。例如這里:https://facebook.github.io/re...
但這確實(shí)是一個(gè)【打開了安全倉(cāng)口】的潛在風(fēng)險(xiǎn)行為,通過原生 JS 直接修改 DOM 的操作是冗余、不安全和不符合 React 思想的,建議以 JSX 的方式考慮所要解決的問題。
回答3:肯定是有其他方法可以做到的,可以考慮classnames的包,樓上用的ref也是一個(gè)常用的方法
標(biāo)簽:
JavaScript
相關(guān)文章:
1. mysql - 把一個(gè)表中的數(shù)據(jù)count更新到另一個(gè)表里?2. mysql 查詢身份證號(hào)字段值有效的數(shù)據(jù)3. node.js - 為什么微信的消息MsgId出現(xiàn)重復(fù)了,無法排重了。。4. mysql的主從復(fù)制、讀寫分離,關(guān)于從的問題5. MySQL 截短某一列的字符串6. 請(qǐng)教使用PDO連接MSSQL數(shù)據(jù)庫(kù)插入是亂碼問題?7. mysql - 分庫(kù)分表、分區(qū)、讀寫分離 這些都是用在什么場(chǎng)景下 ,會(huì)帶來哪些效率或者其他方面的好處8. mysql - 字符串根據(jù)字典替換9. 視頻文件不能播放,怎么辦?10. node.js - nodejs開發(fā)中常用的連接mysql的庫(kù)
排行榜

熱門標(biāo)簽