Maison  >  Questions et réponses  >  le corps du texte

javascript - Des doutes sur setTimeout et Promise

a exprimé sa confusion quant à la différence entre setTimeout(resolve('World'), ms);setTimeout(resolve, ms, 'World'); et

. 🎜

function timeout(ms = 100) {

  /*1. 为何这种写法,立即返回数据而不是等到过了 ms 后才返回*/
  // return new Promise((resolve, reject) => {
  //   setTimeout(resolve('World'), ms);
  // });

  /*2. 为何这种写法,等到过了 ms 后才返回*/
  return new Promise((resolve, reject) => {
    setTimeout(resolve, ms, 'World');
  });
}

timeout(1000)
  .then(value => {
    console.log(`Hello, ${value}`);
  })
  .catch(err => {
    console.error(err);
  });
代言代言2665 Il y a quelques jours785

répondre à tous(5)je répondrai

  • 習慣沉默

    習慣沉默2017-06-12 09:23:50

    C'est la différence entre func() et func. Le premier paramètre de setTimeout est func() est utilisé, cela équivaut à ce que sa valeur de retour soit le premier paramètre.
    Par exemple :

    function test(){
        console.log('this is test!');
        return function () {
            console.log('this is return!');
        }
    }
    
    setTimeout(test(), 1000);

    à peu près équivalent à :

    console.log('this is test!');
    setTimeout(function () {
            console.log('this is return!');
        }, 1000);

    répondre
    0
  • 三叔

    三叔2017-06-12 09:23:50

    Le premier paramètre passé est exécuté immédiatement, pas le nom de la fonction

    répondre
    0
  • 淡淡烟草味

    淡淡烟草味2017-06-12 09:23:50

    et Promise无关,当你执行到setTimeout(resolve('World'), ms);时,浏览器就已经自动执行了resolve('World'), par exemple :

    var test = function(value){
                console.log(value);
            }
            setTimeout(test('hello') , 2000);

    Exécuter immédiatement à ce momenttest.

    répondre
    0
  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-06-12 09:23:50

    Le premier paramètre de setTimeout doit être une fonction

    Une fonction

    Une fonction

    (Pourquoi tant de gens ne comprennent pas)

    setTimeout(resolve, ms, 'World'); 其中 resolve 是一个函数,因此这段的行为正常
    setTimeout(resolve('World'), ms); 其中 resolve('World') 不是函数,是什么决定于 resolve 的返回值类型,但无论如何,resolve Lorsque enregistrez le timer, celui-ci a déjà été exécuté, donc naturellement il n'y aura pas d'effet de retard

    répondre
    0
  • 巴扎黑

    巴扎黑2017-06-12 09:23:50

    ====================================
    Les réponses suivantes ne sont pas valides : je n'ai pas examiné le questionnez soigneusement. .
    Il n’y a généralement aucune différence.

    Juste ! ! ! !

    Il y a un problème avec la prise en charge de setTimeout(resolve, ms, 'World') dans le navigateur IE. (Il semble que IE <= 9 posera des problèmes)

    Matériaux de référence : (voir la note avec fond jaune à l'intérieur)

    WindowOrWorkerGlobalScope.setTimeout()

    répondre
    0
  • Annulerrépondre