vuejs2.0 提示Cannot read property 'push' of undefined

在进行手动访问页面的时候,出现这种报错,于是进行路径的检查。

app.vue结构:

  <div id="app">
    <m-header></m-header>
     <router-view></router-view>
  </div>

m-header.vue文件:

<button @click="surf">漫游</button>
  methods: {
    // 这是是封装的手动访问链接的事件
    // surf() {
    //   var _this = this;
    //   // console.log(_this);
    //   setTimeout(function() {
    //     //   每隔一段时间访问一个路由
    //       _this.$router.push('/message');
    //     setTimeout(function() {
    //       //   每隔一段时间访问一个路由
    //       _this.$router.push({name:'contract',params:{name:'黄华华'}});
    //     }, 2000);
    //   }, 2000);
    // }
  }

发现没有声明this 指向的时候,this并不是指向的vue的,所以没有找到surf这个方法,自然就没有push这个属性了所以就必须 要设置 this的指向,指向当前的方法,所以跳转 路由的时候才不会报错。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
当出现错误提示"TypeError: Cannot read property 'push' of undefined"时,通常意味着你正在尝试对一个未定义的属性进行操作。具体到你的问题,报错的信息是"Cannot read property 'push' of undefined",这意味着你正在尝试对一个未定义的对象进行push操作。 该错误通常发生在以下几种情况下: 1. 你可能没有正确初始化该对象或数组。在使用push方法之前,需要确保该对象或数组已经被正确定义和初始化。 2. 该对象可能是一个null或undefined值。在对一个没有被赋值的变量进行push操作时,会出现该错误。需要确保该对象有有效的值或参考。 解决这个问题的方法包括: 1. 在使用push方法之前,确保你已经正确初始化了该对象或数组。可以使用字面量、构造函数或赋值语句来初始化对象或数组。 2. 在进行push操作之前,检查该对象是否为null或undefined。可以使用if语句或条件运算符来判断并处理这种情况。 需要注意的是,具体解决方法可能因你的代码和上下文而异。希望以上信息能帮助你找到问题并解决它。如果你需要更多帮助,请提供更多的代码或上下文信息。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Cannot read propertypush‘ of undefined 错误解释并解决 通用](https://blog.csdn.net/weixin_46547740/article/details/117018172)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [获得多个复选框 checkbox 选的值(jquery)+ 解决 Uncaught TypeError: Cannot read propertypush‘ ...](https://blog.csdn.net/u011314442/article/details/87796126)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Vue打包Cannot read property 'tapPromise' of undefined报错处理.docx](https://download.csdn.net/download/rongbo91/77070400)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值