我的代码:

let AuthUser = data => {
  return google.login(data.username, data.password).then(token => { return token } )
}

当我试图运行这样的东西:

let userToken = AuthUser(data)
console.log(userToken)

我得到:

Promise { <pending> }

但是为什么呢?

我的主要目标是得到令牌从google.login(数据。用户名,data.password),返回一个承诺,到一个变量。然后再执行一些动作。


当前回答

then方法返回一个挂起的承诺,该承诺可以通过在then调用中注册的结果处理程序的返回值异步解析,也可以通过在被调用的处理程序中抛出错误来拒绝。

因此,调用AuthUser不会突然同步地让用户登录,而是返回一个承诺,在登录成功(或失败)后调用该承诺的注册处理程序。我建议通过登录承诺的then子句触发所有登录处理。例如,使用命名函数来突出显示流的顺序:

let AuthUser = data => {   // just the login promise
  return google.login(data.username, data.password);
};

AuthUser(data).then( processLogin).catch(loginFail);

function processLogin( token) {
      // do logged in stuff:
      // enable, initiate, or do things after login
}
function loginFail( err) {
      console.log("login failed: " + err);
}

其他回答

then方法返回一个挂起的承诺,该承诺可以通过在then调用中注册的结果处理程序的返回值异步解析,也可以通过在被调用的处理程序中抛出错误来拒绝。

因此,调用AuthUser不会突然同步地让用户登录,而是返回一个承诺,在登录成功(或失败)后调用该承诺的注册处理程序。我建议通过登录承诺的then子句触发所有登录处理。例如,使用命名函数来突出显示流的顺序:

let AuthUser = data => {   // just the login promise
  return google.login(data.username, data.password);
};

AuthUser(data).then( processLogin).catch(loginFail);

function processLogin( token) {
      // do logged in stuff:
      // enable, initiate, or do things after login
}
function loginFail( err) {
      console.log("login failed: " + err);
}

试试这个

var number1 = document.getElementById("number1"); var number2 = document.getElementById("number2"); startAsync.addEventListener("click", function() { if (number1.value > 0 && number2.value > 0) { asyncTest(parseInt(number1.value), parseInt(number2.value)).then(function(result) { document.getElementById("promiseResolved").textContent = "promiseResolved: " + result }); } else { asyncTest(1, 2).then(function(result) { document.getElementById("promiseResolved").textContent = "promiseResolved: " + result }); } }); async function asyncTest(a, b) { return await (a + b); }; <button id="startAsync">start Async function</button><br /> <input type="number" id="number1" /><br /> <input type="number" id="number2" /><br /> <span id="promiseResolved"></span><br />

我知道这个问题2年前就被问过了,但我遇到了同样的问题,问题的答案是自ES2017以来,你可以简单地等待函数的返回值(截至目前,只适用于异步函数),比如:

let AuthUser = function(data) {
  return google.login(data.username, data.password)
}

let userToken = await AuthUser(data)
console.log(userToken) // your data

如果这种情况发生在一个多值的数组中。

[ 
  Promise { <pending> },
  Promise { <pending> },
  Promise { <pending> },
  Promise { <pending> },
  Promise { <pending> }
]

你可以使用Promise.all()来解决所有的promise。

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/all

我的情况(JS),我忘记添加等待