我倾向于通过构建一个行人版本来理解正在发生的事情,这足以说明我陷入了必须检查 executor
函数是否已传递到的地步构造函数
,其参数为resolve
和reject
。
这是测试结果。
it('gets called with two different functions (funception!), resolve and reject', function() {
var promise = new $Promise(executor); // eslint-disable-line no-unused-vars
var argsPassedIntoExecutor = executor.calls.argsFor(0);
expect(argsPassedIntoExecutor.length).toBe(2);
var resolve = argsPassedIntoExecutor[0];
var reject = argsPassedIntoExecutor[1];
expect(typeof resolve).toBe('function');
expect(typeof reject).toBe('function');
expect(resolve).not.toBe(reject);
});
到目前为止我所拥有的:
function $Promise(fnc) {
if (typeof arguments[0] !== 'function') {
throw new TypeError('Sorry argument passed to $Promise should an executor function');
}
function ArgumentsToArray(args) {
return [].slice.apply(args);
}
console.log(ArgumentsToArray.apply(fnc));
this._state = 'pending';
this._value = null;
this._internalResolve = function(data) {
if (this._state !== 'pending') return;
this._value = data;
this._state = 'fulfilled';
};
this._internalReject = function(data) {
if (this._state !== 'pending') return;
this._value = data;
this._state = 'rejected';
};
return fnc();
}
这是我尝试过的(摘自上面)但无济于事:
function ArgumentsToArray(args) {
return [].slice.apply(args);
}
console.log(ArgumentsToArray.apply(fnc));
任何帮助将不胜感激!
最佳答案
对于你的问题,JavaScript 中不存在命名参数,我们拥有的是带有 length
属性和参数解构的函数 arity (带有警告)。因此无法测试“参数名称”。对于您的测试,您可以这样做:
const spy = ( resolve, reject ) => {
expect(typeof resolve).toBe("function");
expect(typeof resolve).toBe("function");
};
并将这个 spy 传递给您的构造函数。
这是一项有趣的尝试,但您应该尝试从规范开始。规范引入的 Promise
构造函数主要是为了可发现性(使用 constructor
属性)。
以下是规范:https://promisesaplus.com/ ,只需尝试理解并重新实现一个简单的 resolve
程序作为初学者,规范确实有一个测试套件可以帮助您(作为 npm 包分发)。
关于javascript - 如何获取传递给 JavaScript 函数的函数参数名称?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46830595/