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

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);
          }),
        };
    
    评论

报告相同问题?

悬赏问题

  • ¥15 链接问题 C++LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型
  • ¥15 求学软件的前人们指明方向🥺
  • ¥50 如何增强飞上天的树莓派的热点信号强度,以使得笔记本可以在地面实现远程桌面连接