首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >api回调中的Vue调用方法

api回调中的Vue调用方法
EN

Stack Overflow用户
提问于 2021-10-19 09:54:46
回答 1查看 342关注 0票数 0

我使用的是支付api,其中有一个来自api的回调方法,它表示事务的状态。

代码语言:javascript
运行
复制
  async makePayment() {
            this.$launchFlutterwave({
                tx_ref: Date.now(),
                amount: this.amount,
                currency: "KES",
                customer: {
                    email: "user@gmail.com",
                    phonenumber: this.user.phone_number,
                    name: this.user.name,
                    plot_unique_id: this.plot_unique_id
                },
                callback: function(data) {
                    
                    console.log(data);
                    this.registerPayment(data);
                },
                customizations: {
                    title: "",
                    description: ",
                    logo: "https://assets.piedpiper.com/logo.png"
                }
            });
        },

 async registerPayment(data) {
            console.log("hit");
            await axios.post("/api/flutterwave/register/payment", data);
        }

在回调中,我想注册一个方法

代码语言:javascript
运行
复制
  callback: function(data) {
        console.log(data);
        this.registerPayment(data);
     },

然后,该方法将接收到的后台数据和其他特定于用户的数据发布到后端。

代码语言:javascript
运行
复制
 async registerPayment(data) {
       console.log("hit");
       await axios.post("/api/flutterwave/register/payment", data);
  }

但是,当调用回调中的方法时,我将收到错误Uncaught TypeError: this.registerPayment is not a function

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-10-19 09:57:43

这是因为回调内部的上下文是不同的:

代码语言:javascript
运行
复制
callback: function(data) {
  console.log(this); // you will see registerPayment doesnt exist here
  this.registerPayment(data);
},

为什么不直接使用registerPayment呢?你可以这样做:

代码语言:javascript
运行
复制
callback: this.registerPayment

如果仍然希望从registerPayment内部调用callback,可以使用箭头函数访问外部上下文:

代码语言:javascript
运行
复制
callback: (data) => {
  this.registerPayment(data);
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69628728

复制
相关文章

相似问题

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