React Router 的参数不起作用
2016-07-29
6584
我有一个待办事项应用程序,我正在尝试选择一个项目并将其发送到要编辑的页面。我看了一下这篇文章
从 react-router hash fragment 获取查询参数
并注意到他们正在使用
this.props.location.query
我想要完成的是获取查询参数并将其显示在输入框中以供编辑。
import * as React from 'react'
import { Router, Route, IndexRoute, hashHistory, browserHistory, Link } from 'react-router'
import {ITask, IStoreAction, ActionType} from '../model/TasksModel'
import store from '../store/Store'
interface TaskEditProp {
task: ITask
}
class TaskEdit extends React.Component<TaskEditProp, {}>{
constructor() {
super();
this.state = store.getState()
store.subscribe(() => {
this.setState(store.getState())
})
//todo: console.log(this.props.location);
}
onSave = (e) => {
e.preventDefault();
var refs: any = this.refs;
var task: ITask = {
index: this.props.task ? this.props.task.index : 0,
text: refs.text.value,
done: false
}
var storeAction: IStoreAction = {
type: ActionType.EDIT_TASK,
task
}
store.dispatch(storeAction)
browserHistory.push('/')
}
onCancel = (e) => {
e.preventDefault();
browserHistory.push('/')
}
render() {
const { props: { children } } = this;
return (
<div className="">
<h3>Edit Task</h3>
<form onSubmit={this.onSave}>
<fieldset className="form-group">
<label for="task">Task</label>
<input type="text" ref="text" className="form-control" >{this.props.location}</input>
</fieldset>
<div className="btn-group">
<button className="btn btn-primary" >Save</button>
<button className="btn btn-warning" onClick={this.onCancel} >Cancel</button>
</div>
</form>
</div>
)
}
}
export default TaskEdit;
我假设我的界面不包含位置,所以 props 不知道位置。
这是我的路线的定义方式:
var Routes = (
<Router history={browserHistory}>
<Route path="/" component={Tasks}>
<IndexRoute component={TaskList} />
<Route path="/add" component={TaskAdd} />
<Route path="/edit/:id" component={TaskEdit} />
</Route>
<Route path="/about" component={About}/>
</Router>
)
我的商店调度后,我正在调用
browserHistory.push('/edit/'+task.index)
,它将我发送到正确的视图,但我无法访问查询参数。我的其余代码可以在
https://github.com/crh225/HotReactAsp/tree/master/src/HotReactAsp/content
找到,谢谢!
2个回答
您可以只打印
this.props
来查看 props 的呈现方式,并找到提取所需数据的正确方法。
我不知道您使用的是哪个版本的
react-router
,但据我所知,获取查询参数的正确方法是:
let { id } = this.props.params;
而这个
index: this.props.task ? this.props.task.index : 0,
将是
index: this.props.params.id ? this.props.params.id : 0,
shadeglare
2016-07-30
我确信你现在已经解决了这个问题,但你需要使用 routerProps 扩展你的接口。你需要 @types:react-router-dom
Import { withRouter, Switch, Route, NavLink, RouteProps } from 'react-router-dom';
interface TaskEditProp extends RouteProps {
task: ITask
}
JamesTBennett
2018-06-19