React-Router:为什么 <Link>组件的 onClick 处理程序不会调度我的操作
React-Router: Why won't <Link> component's onClick handler dispatch my action?
我希望 React-Router 的<Link>
在单击时触发一个函数,但看起来<Link>
在函数有机会触发之前导航到下一页。
我的组件看起来像这样:
<Link to={`/path/to/${foo}`} onClick={() => myFunc(foo, bar)}>
<div>This is my Link</div>
</Link>
foo
和bar
是从父组件传下来的道具。
但是,如果我调用 e.preventDefault
,任何后续函数都可以正常工作:
<Link
to={`/path/to/${foo}`}
onClick={(e) => e.preventDefault(); console.log('This works!')}>
<div>This is my Link</div>
</Link>
我想我可以做类似的事情,然后以编程方式导航到我的路线,但必须有一种更好(即更少的黑客)方法来实现这种效果。
有人有任何建议,可能对我有所帮助吗?
这
直接不是解决方案,但您可以尝试不使用Link
组件,使用简单的a
元素,并在处理程序onClick
移动到所需的路由:
import { browserHistory } from 'react-router';
<a onClick={
browserHistory.push(`/path/to/${foo}`)
myFunc(foo, bar)
}>
<div>This is my Link</div>
</a>
相关文章:
- keyup事件处理程序更改焦点不适用于快速键入
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- 提示使用服务器端事件处理程序激活JavaScript
- 将事件处理程序绑定到任何可能的事件
- 正在将事件处理程序添加到不存在的类
- 在AJAX回调和呈现PIXIJS之间处理程序流时遇到了问题
- Adobe Edge:动画完成时添加onComplete处理程序
- 是否可以从输入处理程序中确定输入的类型
- 在MVVM视图模型中处理应用程序范围的元素
- 在循环中附加事件处理程序时出现浏览器性能问题
- 在同一个javascript事件处理程序中调用不同的函数
- 有没有一种方法可以让内联事件处理程序在元素创建后立即执行
- 检查事件处理程序参数
- 实现延迟的jquery更改事件处理程序
- 如何使用Python/Selenium网络驱动程序处理Angularjs/Javascript下拉列表
- 在 AJAX 完成之前,不要让其他处理程序处理
- 如何使用硒铬驱动程序处理地理位置弹出窗口
- 如何使用硒网络驱动程序处理 onblur 事件
- 是否有一种方法为chrome打包应用程序处理Http BasicAuthentication
- Ajax加载程序处理问题