Vue里面的html代码里不能直接写跳转吗?会报错Cannot read property '$router' of null

<li class="col25" @click="this.$router.push({name:'RentList'})"><img width="32px" height="32px" src="../assets/images/home1.png"/><span style="display:block;">我的租房</span></li>

难道一定要把js代码写在method里?

阅读 6.3k
3 个回答

1、在进行模板渲染的时候,这里是没有 $router 对象的, vue 提供有 <router-link to="/foo">Go to Foo</router-link> 供模板路由。

this指向不对
直接 @click="$router.push({....})"

去掉this就行了

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题