ant design Pro 跳转路由--带参数的跳转
2019-07-27 本文已影响0人
miner敏儿
近期使用ant design Pro 项目中遇到跳转路由的问题,
一开始是遇到创建 跳转到创建页面的问题
这一篇文章干货满满哦
首先 我的跳转的路径是在modal中写的
上代码
routerRedux跳转路由 /router
import router from ‘umi/router’;
import { routerRedux } from ‘dva/router’;
不带参数的路由跳转
首先使用import { routerRedux } from 'dva/router';
modal中
然后在js中点击创建按钮进行跳转
data:image/s3,"s3://crabby-images/f26ba/f26ba6a671579bb6a0aa6ad3a4614b48c791a6ba" alt=""
带参数id的路由跳转
-
同样 跳转路径还是写在modal中
-
在这里插入图片描述
首先在路由配置的地方也要改
在这里插入图片描述
在js中同样的方式dispatch调用
在这里插入图片描述
在create的页面中
componentDidMount () {
console.log(this.props.match.params.id)
}
拿到跳转后的id的值
带参数data的路由跳转
modal中同样
data:image/s3,"s3://crabby-images/ecf67/ecf67fd1aa83d5cf3c8dbc5f42f9a8d5645644d8" alt=""
使用json.stringify先把对象解析
router.config.js中
data:image/s3,"s3://crabby-images/13738/137386dbece208b8ffe0379ad55bb3a813572076" alt=""
在创建点击的事件中同样
data:image/s3,"s3://crabby-images/a249f/a249fb4a88d271965e840b3250f1c5e1fbc74fb8" alt=""
在create的页面中
componentDidMount () {
console.log(this.props.match.params.data)
}
data:image/s3,"s3://crabby-images/75338/75338ce11f540dc9be3e55a51b19e603378bb409" alt=""
需要在转化成对象
componentDidMount () {
console.log(JSON.parse(this.props.match.params.data))
}
data:image/s3,"s3://crabby-images/9f043/9f043af7a4b7e9534bfc62020296cda4b95c85d5" alt=""
以下的方法中router中都不需要配置
params传参跳转(不推荐, 刷新后获取不到参数值)
// 创建
onCreate = () => {
this.props.dispatch(routerRedux.push({
pathname: '/api-manage/create-sub-system',
params: {
id: 6,
value: 'lala',
}
}))
};
创建的页面通过
this.props.location
获取到值
data:image/s3,"s3://crabby-images/f0498/f049810e7306d8ddeef84f3f0ee0275516c191e7" alt=""
但是在当前页面进行刷新以后就获取不到params的值了
data:image/s3,"s3://crabby-images/bb575/bb575db52d30922fd89561fb5b0ff94c6f051538" alt=""
但是通过上述两个的对比可以看出query一直存在, 所以我们可以通过query来进行路由传参
query路由传参(推荐)
// 创建
onCreate = () => {
this.props.dispatch(routerRedux.push({
pathname: '/api-manage/create-sub-system',
query: {
id: 6,
value: 'lala',
}
}))
};
创建页面通过this.props.location
data:image/s3,"s3://crabby-images/1d3f9/1d3f9b42f4886d2b52e76e35576ab4111247899e" alt=""
Link 进行路由跳转(极力推荐)
import Link from 'umi/link';
import Link from 'umi/link';
<Link to={{
pathname: '/api-manage/create-sub-system',
query: {
id: 6,
value: 'lala',
}
}}>
<Button
style={{ marginLeft: 8 }}
type="primary"
// onClick={this.onCreate}
>
<Icon type="plus" />
创建
</Button>
</Link>
create页面 this.props.location
拿到值
同query一样的还有一个state方式, 只是属性不一样, state传的参数是加密的, query 传的参数是公开的,
以上通过过r Link parmas state 或者routerRedux.push方式的路由跳转传参都可以使用js中的 this.props.history.push方式