如何使用ReactJS调用由childda事件引起的childdb方法
How to call a method of childB caused by an event in ChildA using ReactJS
我正在使用React为我的项目和相当新的使用它。下面是我面临的问题。
我有以下组件结构:
<Parent>
<ChildA></ChildA>
<ChildB></ChildB>
</Parent>
我想有以下功能:当一个按钮被点击在儿童a,我想要一个方法在儿童db执行。
你能让我知道我们如何在ReactJS中实现这一点吗?
提前感谢!
这个问题有两个直接的答案。
-
使用事件发射器。在childda的点击处理程序中,你发出一个"whatever"事件。child db已经为"whatever"事件注册了一个监听器,因此调用该事件的处理程序。
-
参用。您将一个函数作为prop
<ChildA onWhatever={fn}>
传递给childda,并将ref放在childdb<ChildB ref="b">
上,然后在传递给childda的函数中执行this.refs.b.method()
。
然而,这是XY问题的一个例子。真正好的解决方案可能在于你退一步思考"当按钮被点击时,应该发生什么可观察的变化?"而不是"应该调用什么方法?"
父组件应该包含:
handleClickA: function(){
this.refs.b.AClicked()
},
render: function(){
return <div>
<ChildA onClick={this.handleClickA}></ChildA>
<ChildB ref='b'></ChildB>
</div>
}
相关文章:
- electronic BrowserWindow的最小高度和宽度在hide()show()方法之后不起作用
- 有没有任何方法可以将控制器从文件加载到ui路由器$stateProvider中
- 数组在递归方法中设置为null
- 打破承诺链的好方法是什么
- 在使用Polymer'加载所有json文件后执行方法;s的核心ajax
- 使用“;这个“;JavaScript原型方法中的关键字
- 序列化数据属性中对象的最可靠方法
- 使用Objective-C的JavaScript注入方法
- 有没有一种方法可以添加相同的项目val=“0”;4〃;到JavaScript中数组的每个对象
- 有没有一种方法可以防止img get请求使用css或js发生
- Javascript,有没有一种方法可以将数组写成没有逗号或空格的单个文本字符串
- toBoolean方法类似于toString
- 如何在单击复选框后调用控制器方法
- 是否有任何方法可以使用jQuery替换在数组中定义值的文本
- 递归使用 eval() 是检查程序执行的好方法吗?
- 如何在webView,Android中从@JavascriptInterface方法调用Javascript
- toLocaleDateString和toLocaleString方法不尊重机器时区
- 有条件更新d3.js力图中节点的最佳方法
- TypeError:在不兼容的接收器nodejs上调用了方法Uint8Array.length
- 如何使用ReactJS调用由childda事件引起的childdb方法