Link组件用于正常的用户点击跳转,但是有时还需要表单跳转、点击按钮跳转等操作。这些情况怎么跟React Router对接呢? 下面是一个表单。
第一种方法是使用browserHistory.push
// ...
handleSubmit(event) {
event.preventDefault()
const userName = event.target.elements[0].value
const repo = event.target.elements[1].value
const path =
browserHistory.push(path)
},
handleSubmit(event) {
event.preventDefault()
const userName = event.target.elements[0].value
const repo = event.target.elements[1].value
const path =
/repos/${userName}/${repo}
browserHistory.push(path)
},
第二种方法是使用context对象。
// ask for
contextTypes: {
router: React.PropTypes.object
},handleSubmit(event) {
// ...
this.context.router.push(path)
},})
router
from contextcontextTypes: {
router: React.PropTypes.object
},handleSubmit(event) {
// ...
this.context.router.push(path)
},})