html5 - Problèmes rencontrés dans les livres de programmation asynchrone javascript?
天蓬老师
天蓬老师 2017-05-16 13:42:47
0
3
519

Relisez le livre JavaScript Asynchronous Programming, puis j'ai vu un morceau de code

var webSocketCache = {};
function openWebSocket(serverAddress, callback) {
    var socket;
    if (serverAddress in webSocketCache) {
        socket = webSocketCache[serverAddress];
        if (socket.readyState === WebSocket.OPEN) {
            callback();
        } else {
            socket.onopen = _.compose(callback, socket.onopen);
        };
    } else {
        socket = new WebSocket(serverAddress);
        webSocketCache[serverAddress] = socket;
        socket.onopen = callback;
    };
    return socket;
};

C'est dit dans le livre

        var socket=openWebSocket(url,function(){
          socket.send('Hello,server!');      
        });

Cela provoquera un crash du code, ce qui prête à confusion. . Pourquoi l'appel d'une fonction de rappel avant de renvoyer une valeur fait planter le code. J'espère que vous pourrez m'aider à expliquer

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

répondre à tous(3)
Peter_Zhu

La fonction de rappel peut être exécutée avant le retour, et le socket à ce moment-là n'a pas reçu de valeur

Vous pouvez passer un paramètre au callback pour éviter cette situation

巴扎黑

Avez-vous défini l'url ? - -

漂亮男人
const func = function (callback) {
    callback();
    return 100;
};

const x = func(() => {
    console.log(x); //此处将打印 undefined;
});

console.log(x); //此处打印 100

Je me demande si vous pouvez comprendre cette explication ?

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal