开发者问题收集

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