javascript - Reactjs关于函数内跳转 this.context.router.push(path)的问题
问题描述
请教各位师兄了。我创建了一个组件Component,并在内部中的一个ajax成功回调内,写了this.context.router.push('/user/list')类似的跳转功能。同时在组件外写了Component.contextTypes={ router: React.PropTypes.object.isRequired }。ajax也成功请求了,但是页面并没有跳转,有点疑问了。。。代码结构类似:
class Component extends React.Component{ ... success: function(data) {alert(data);this.context.router.push(...) }}Component.contextTypes={ router: React.PropTypes.object.isRequired}
问题解答
回答1:是不是拿不到this?. 试试用 success()->()
回答2:这里写一下在网上查找答案时遇到的坑,同时也是为了告诉后来遇到同样或者相似问题的小白吧,还请相关帖子管理人员别删:在 Component.contextTypes这儿,我查到过有人把它以这种方式写到过组件内部:
class Component extends React.Component{ [有些人写static有些人又不写static] contentTypes: {router: React.PropTypes.object.isRequired } ... this.context.router.push(...)}
然而这么做我这儿始终出问题,就是报错 Cann’t read the property ’push’ is not defined。不太明显为啥呢,先记下来再说吧
回答3:'Cann’t read the property ’push’ is not defined'这个错误确保contextTypes写好了并且构造函数调用super是没有把context弄丢
class Component { constructor(props, context) { super(...arguments) // 这样才行,如果只写props, 会把context 弄丢,所以super时始终建议这么写 }}
相关文章:
1. android - java tm platform se binary 占用很多内存2. mysql 怎么做到update只更新一行数据?3. javascript - CSS图片轮播显示问题4. javascript - ajax 图片文件与文本框数据一起提交上传处理5. javascript - 项目用IE浏览器打开修改前端内容,后台数据修改了,但是前端页面内容不变,用谷歌浏览器测试前端页面可以刷新,求大神解决。6. javascript - 关于js高级程序中的问题7. windows-7 - win7下使用cmder,如何设置vim的tab为4个空格?8. thinkPHP5中获取数据库数据后默认选中下拉框的值,传递到后台消失不见。有图有代码,希望有人帮忙9. Java中的多人游戏。将客户端(玩家)连接到其他客户端创建的游戏10. node.js - 关于mongoose方法的回调函数的参数问题,如何知道参数个数以及参数代表什么含义呢?

网公网安备