最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Waiting for async request to return before proceeding Google Apps Script - Stack Overflow

programmeradmin0浏览0评论

Some code in Google Apps Script I am currently producing has a need for an object to be pleted with one of the properties being set by the result of an async request. This object, and specifically, this property are then used later down the line. However, because the request has not returned by the time the functions needing that property run, they are not evaluating properly. My code is as follows:

function Thing(val) {
    var self = this

    var createSuccess = function(data) {
        self.foo = data;
    }

    var init = function(val) {
        google.script.run.withSuccessHandler(createSuccess).serverFunc(val);
    };

    init(val);
}

function objStuff() {
    var foobar = new Thing('bar');
    // Do stuff with foobar.foo
}

objStuff();

Currently the stuff using foobar.foo does not work correctly, as the script has not waited for the return value of the script before proceeding.

Is there a way I can wait for the foo property to be evaluated with the async request before proceeding with the rest of my script?

Some code in Google Apps Script I am currently producing has a need for an object to be pleted with one of the properties being set by the result of an async request. This object, and specifically, this property are then used later down the line. However, because the request has not returned by the time the functions needing that property run, they are not evaluating properly. My code is as follows:

function Thing(val) {
    var self = this

    var createSuccess = function(data) {
        self.foo = data;
    }

    var init = function(val) {
        google.script.run.withSuccessHandler(createSuccess).serverFunc(val);
    };

    init(val);
}

function objStuff() {
    var foobar = new Thing('bar');
    // Do stuff with foobar.foo
}

objStuff();

Currently the stuff using foobar.foo does not work correctly, as the script has not waited for the return value of the script before proceeding.

Is there a way I can wait for the foo property to be evaluated with the async request before proceeding with the rest of my script?

Share Improve this question edited Oct 3, 2021 at 23:43 Wicket 38.8k9 gold badges80 silver badges195 bronze badges asked Jun 4, 2017 at 21:55 dbrdbr 6891 gold badge8 silver badges22 bronze badges 0
Add a ment  | 

2 Answers 2

Reset to default 6

You can add a callback as a parameter to the constructor:

function Thing(val, cb) {
    var self = this

    var createSuccess = function(data) {
        self.foo = data;
        cb(); // this gets called when data is ready
    }

    var init = function(val) {
        google.script.run.withSuccessHandler(createSuccess).serverFunc(val);
    };

    init(val);
}

function objStuff() {
    var foobar = new Thing('bar', function() {
        // Do stuff with foobar.foo
    });
}

objStuff();

My reendation would be to use the events module if you are making use of nodejs since it allows you to create an event listener.

So you could do something like

eventEmitter.on('listener_key', function(){
    //your code to be executed after the event
});

funtion emitStuffToListener(){
 eventEmitter.emit('listener_key');
}

EDIT: sorry I missread the post but you can still do event oriented development with Google Apps Event Objects

发布评论

评论列表(0)

  1. 暂无评论