快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

react路由传值的方式有哪些

这篇文章主要介绍“react路由传值的方式有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“react路由传值的方式有哪些”文章能帮助大家解决问题。

成都创新互联技术团队10多年来致力于为客户提供成都网站设计、做网站高端网站设计营销型网站、搜索引擎SEO优化等服务。经过多年发展,公司拥有经验丰富的技术团队,先后服务、推广了上1000+网站,包括各类中小企业、企事单位、高校等机构单位。

react路由传值有三种方式:1、“props.params”方法,该方法可以传递一个或多个值,但是每个值的类型都是字符串,没法传递一个对象;2、query方法,该方法类似于表单中的get方法,传递参数为明文,但是刷新页面参数会丢失;3、state方法,该方法获取参数时要用“this.props.match.params.name”,并且刷新页面参数也会丢失。

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react路由传值的方式

路由传值的方法有三种

1.props.params(推荐)

//设置路由
 
    
 
import { Router,Route,Link,hashHistory} from 'react-router';
class App extends React.Component {
  render() {
    return (      
        用户
        // 或者
        hashHistory.push("/user/sam");
    )
  }
}

当页面跳转到UserPage页面之后,取出传过来的值:

export default class UserPage extends React.Component{
    constructor(props){
        super(props);
    }
    render(){
        return(
this.props.match.params.name
)     } }

上面的方法可以传递一个或多个值,但是每个值的类型都是字符串,没法传递一个对象,如果传递的话可以将json对象转换为字符串,然后传递过去,传递过去之后再将json字符串转换为对象将数据取出来

//定义路由

//设置参数
var data = {id:3,name:sam,age:36};
data = JSON.stringify(data);
var path = `/user/${data}`;
//传值
用户
//或
hashHistory.push(path);
//获取参数
var data = JSON.parse(this.props.params.data);
var {id,name,age} = data;

2.query(不推荐:刷新页面参数丢失)

query方式使用很简单,类似于表单中的get方法,传递参数为明文

//定义路由

//设置参数
var data = {id:3,name:sam,age:36};
var path = {
  pathname:'/user',
  query:data,
}
//传值
用户
//或
hashHistory.push(path);
//获取参数
var data = this.props.location.query;
var {id,name,age} = data;

3.state(不推荐,刷新页面参数丢失)

state方式类似于post方式,使用方式和query类似

//设置路由

//设置参数
var data = {id:3,name:sam,age:36};
var path = {
  pathname:'/user',
  state:data,
}
//传值
用户
//或
hashHistory.push(path);
//获取参数
var data = this.props.location.state;
var {id,name,age} = data;

特别提示:

1,获取参数时要用this.props.match.params.name

2,如果在子组件里打印要记得传this.props,如下:

class Todolist extends Component {
    render() {
       return (
           
              
           
               //不传的话this.props为空对象            
                               
                   );     }  } export default Todolist;

关于“react路由传值的方式有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注创新互联行业资讯频道,小编每天都会为大家更新不同的知识点。


网站标题:react路由传值的方式有哪些
网站URL:http://6mz.cn/article/pjgish.html

其他资讯