文章详情页
javascript - react如何不通过state去修改classname?
浏览:160日期: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
相关文章:
1. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)2. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题3. mysql - SQL操作时间的函数?4. java - mybatis怎么实现在数据库中有就修改,没有就添加5. docker内创建jenkins访问另一个容器下的服务器问题6. 正则表达式 - python pandas的sep参数问题7. javascript - 用表单提交两个时间段请求后台返回对应数据时出现的一些问题!8. angular.js - angularjs的自定义过滤器如何给文字加颜色?9. MYSQL新建用户设置可以远程访问的问题10. docker api 开发的端口怎么获取?
排行榜
![$fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题](http://www.haobala.com/attached/image/news/202205/093622cb60.png)