首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Vue TypeError:这是未定义的

Vue TypeError:这是未定义的
EN

Stack Overflow用户
提问于 2020-01-20 14:11:09
回答 2查看 1.4K关注 0票数 1

为什么这里没有定义this?注销时,单击这是浏览器控制台TypeError: this is undefined中显示的错误

代码语言:javascript
复制
<script lang="ts">
import Vue from "vue";
import { getModule } from "vuex-module-decorators";
import Component from "vue-class-component";
import AuthModule from "@/store/auth";
import Store from "@/store";

const authModule = getModule(AuthModule, Store);

@Component({})
export default class App extends Vue {
  mounted() {
    console.log("App mounted");
  }
  onLogoutClick() {
    authModule.logout().then(function() {
      this.$router.push("/login");
    });
  }
 }
</script>
EN

回答 2

Stack Overflow用户

发布于 2020-01-20 14:15:24

尝尝这个。

代码语言:javascript
复制
     methods: {
       onLogoutClick() {
        let self = this
        authModule.logout().then(function() {
          self.$router.push("/login");
        });
      }
票数 1
EN

Stack Overflow用户

发布于 2020-01-20 14:44:20

对匿名函数使用箭头函数可以解决这个问题。因为箭头函数将this绑定到词法作用域的this (在本例中是onLogoutClick的this)。

代码语言:javascript
复制
onLogoutClick() {
    authModule.logout().then(() => {
      this.$router.push("/login");
    });
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59817814

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档