如何从javascript函数内部调用React组件函数
How to call a React component function from inside a javascript function?
我在一个事件函数中,我想创建一个新的警报弹出窗口(我使用的是react门户库(:
onNewAlert: function(username) {
var divModal = (
<Portal ref={'Portal'+username}>
<div id={'div'+username}>
<br /><br/ >Alert for {username}
</div>
</Portal>);
...
}
但是我必须调用Portal
中的一个函数。如果我在render()
函数中,我通常可以使用引用来执行此操作,但我在一个事件中。
this.refs['Portal'+username].openPortal(); // openPortal is a function of the Portal component
有没有一种方法可以为javascript函数中动态创建的组件调用组件函数?
即使可以调用portal.openPortal()
,它也不会执行任何操作,因为在事件处理程序中创建的组件不会附加到DOM。
事件处理程序不应该尝试在事件处理程序函数中呈现Portal,而应该更改将触发render()
的组件状态。
onNewAlert: function(username) {
this.setState({ showAlert: true });
}
render()
函数将使用Portal
组件的isOpened
属性的状态变量:
render: function () {
return (
<div>
...
<Portal isOpened={this.state.showAlert}>
...
</Portal>
</div>
);
}
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- HTML5(Bootstrap)通过函数调用运行动画
- 函数调用不起作用
- 函数中的Javascript函数调用