pudding_ning 2020-03-04 15:10 采纳率: 0%
浏览 760

angular 8.0 项目中使用 this.router.navigate 报错:TypeError: Cannot read property 'navigate' of undefined ?

1.问题描述:

在 angular 8.0搭建的项目中,使用 jstree 树结构的时候,在 箭头函数里面使用了 this.router.navigate(['pages/devicemanage/ccap/id', clickedNode.id]);
进行路由的跳转。报错如下:
TypeError: Cannot read property 'navigate' of undefined。

2.具体代码如下所示:

    items['detail'] = {
      "label": "Detail",
      "icon": "fas fa-info",
      "action": ((obj)=> {
        var inst = jQuery.jstree.reference(obj.reference);
        var clickedNode = inst.get_node(obj.reference);
        this.router.navigate(['pages/devicemanage/ccap/id', clickedNode.id]);
        localStorage.setItem('ccapIp', clickedNode.ip);
      }),
    };

Google 了很久,一直找不到合适的答案,想请教一下各位大神,非常感谢!

  • 写回答

1条回答 默认 最新

  • _老杨_ 2020-03-29 18:12
    关注

    你这个是变量的作用域你没搞仔细
    在你的 "action":((obj)=>{});里边的this就不是外面component的this了。
    在前面声明一个别名保存component的this就可以了

     let self = this;
     items['detail'] = {
          "label": "Detail",
          "icon": "fas fa-info",
          "action": ((obj)=> {
            let inst = jQuery.jstree.reference(obj.reference);
            let clickedNode = inst.get_node(obj.reference);
            self.router.navigate(['pages/devicemanage/ccap/id', clickedNode.id]);
            localStorage.setItem('ccapIp', clickedNode.ip);
          }),
        };
    
    评论

报告相同问题?

悬赏问题

  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条