使用typescript和vuejs+axios,我有以下内容.捕获post请求的函数-我试图捕获一些网络错误并向最终用户报告状态:

      .catch(function(error) {
          console.error(error.response);
          if ( error.message === "Network Error" ) {
              this.alert.show = 1;
              this.alert.message = error.message + ': Please try again later';
          }
      });

这警觉的show在调试器中抛出未定义的"this".这是javascript/typescript和异常处理程序的一个问题,还是Axios中的一个bug,或者是我找不到相关文档的设计决策?

有没有一种方法可以让我在没有"this"引用的情况下,将其传达给我的组件?

全街区:

export default {
  data() {
    return {
      form: {
        email: '',
        password: '',
      },
      alert: {
          show: 0,
          message: '',
      },
    };
  },
  methods: {
    onSubmit(evt) {
      evt.preventDefault();

      if (this.form.password.length > 0) {
          // TODO: Hideous workaround for .catch().
          let that = this;
          this.$http.post('http://localhost:3000/login', {
              email: this.form.email,
              password: this.form.password,
          })
          .then((response) => {
              const is_admin = response.data.user.is_admin;
              localStorage.setItem('user', JSON.stringify(response.data.user));
              localStorage.setItem('jwt', response.data.token);

              if (localStorage.getItem('jwt') != null) {
                  this.$emit('loggedIn');
                  if (this.$route.params.nextUrl != null) {
                      this.$router.push(this.$route.params.nextUrl);
                  } else {
                      if (is_admin === 1) {
                          this.$router.push('admin');
                      } else {
                          this.$router.push('dashboard');
                      }
                  }
              }

          })
          .catch((error) => {
                console.error(error);
                if ( error.message === 'Network Error' ) {
                    this.alert.show = 10;
                    this.alert.message = error.message + ': Please try again later';
                }
          });
      }
    },
    onReset(evt) {
      evt.preventDefault();
      /* Reset our form values */
      this.form.email = '';
      this.form.password = '';
      /* Trick to reset/clear native browser form validation state */
      this.show = false;
      this.$nextTick(() => { this.show = true; });
    },
  },
};

Vue模板(Login.Vue):

<template>
<div>
<b-container class="loginPage">
  <b-row>
    <b-col sm="4"/>
    <b-col sm="4">
      <b-form @submit="onSubmit" @reset="onReset">
         <h2>Login</h2>
         <p>Please enter your email and password</p>
         <b-form-input id="exampleInput1"
                      type="email"
                      v-model="form.email"
                      required
                      placeholder="Enter email">
         </b-form-input>
         <b-form-input id="exampleInput2"
                      type="password"
                      v-model="form.password"
                      required
                      placeholder="Enter password">
         </b-form-input>
      </b-form-group>

        <div class="forgot">
        <a href="reset.html">Forgot password?</a>
        </div>

      <b-button class="btn-primary" type="submit" variant="primary">Submit</b-button>
      <b-button class="btn-reset"   type="reset" variant="danger">Reset</b-button>

      <b-alert :show="alert.show" variant="danger">
         {{alert.message}}
      </b-alert>
    </b-form>

    </b-col>
    <b-col sm="4"/>
  </b-row>
</b-container >


    </div>
</template>

也使用https://bootstrap-vue.js.org.

推荐答案

您正在创建一个新的本地函数范围.用胖箭代替.

.catch((error) => {
      console.error(error.response);
      if ( error.message === "Network Error" ) {
          this.alert.show = 1;
          this.alert.message = error.message + ': Please try again later';
      }
  });

Vue.js相关问答推荐

Vutify-v-工具提示-不使用键盘轻击按钮显示

v-model 修饰符返回空

Vue 脚本标签中更漂亮的 destruct 功能

在 bootstrap-vue 中渲染自定义样式

如何容器化 Vue.js 应用程序?

Defer推迟执行,直到外部脚本加载到 Vue.js

将检测外部点击自定义指令从 Vue 2 迁移到 Vue 3

Nuxt 打开链接到模态

store 的 Vuex Classic 模式已弃用,将在 Nuxt 3 中删除

Vuetify - 如何在 v-data-table 中单击时突出显示行

请求正在进行时显示加载器

如何在 vue 3 中获取路由的参数?

如何在某些路由上隐藏全局组件(例如导航栏)?

删除一行后刷新 Bootstrap-Vue 表

如何在 vue.config.js 中为生产设置 API 路径?

在 Vue JS 组件中使用 Laravel 路由的最佳方法是什么

在 vue.js 组件中react this.props.children

如何设置 :id 前缀字符串?

Vue.js 和 jQuery datepicker/timepicker 双向绑定

如何删除 vue cli 2?