久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

javascript - react如何不通過state去修改classname?

瀏覽:118日期: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>...// 可以在一個事件中通過this.getDom獲取當前元素,再通過className設置this.getDom.className = class1回答2:

原生 JS 操作 DOM 的行為是不推薦的,如果非常需要這個能力,可以通過 ReactDOM 的 findDOMNode 方法去獲取到 DOM 節點的引用。例如這里:https://facebook.github.io/re...

但這確實是一個【打開了安全倉口】的潛在風險行為,通過原生 JS 直接修改 DOM 的操作是冗余、不安全和不符合 React 思想的,建議以 JSX 的方式考慮所要解決的問題。

回答3:

肯定是有其他方法可以做到的,可以考慮classnames的包,樓上用的ref也是一個常用的方法

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 金乡县| 海盐县| 娄底市| 安塞县| 峨眉山市| 扎囊县| 温泉县| 格尔木市| 峨眉山市| 岳普湖县| 镇平县| 武功县| 牡丹江市| 望城县| 西丰县| 延长县| 柯坪县| 彭州市| 鄄城县| 平谷区| 建宁县| 宣化县| 皋兰县| 沁源县| 西乌| 宝山区| 桃园市| 西宁市| 甘孜县| 玉溪市| 万宁市| 桃园县| 漠河县| 东兴市| 江油市| 横峰县| 介休市| 昆明市| 偃师市| 新宁县| 大田县|