2 回答

TA貢獻1848條經驗 獲得超10個贊
returnedFunction函數通過引用進行比較,因此如果您在測試中構建函數,即使它們看起來相同,也不會被視為相等。
您應該引入一些在測試和代碼之間共享引用的方法。例如,
// Note that sharedFn can now be used in your test for comparison
const sharedFn = () => {};
const returnedFunction = () => { return sharedFn; };
...
const received = returnFunction();
expec(received).toBe(sharedFn);

TA貢獻1847條經驗 獲得超11個贊
注意這function是javascript中的保留關鍵字,不能命名變量function
我不確定你到底是什么意思
是類型returnedFunction
您需要知道調用了哪個函數嗎?除非你保留對你的函數的引用(例如在一個對象中),或者為它們分配唯一標識符,否則你不能真正等于函數,事件與toString(),這只會保證兩個函數的字符串表示(代碼)是相同的.
我會嘗試:
let returnedFunction = () => {};
returnedFunction.id = "returnedFunction";
const returnFunction = () => {
const function = returnedFunction;
// Do stuff
return function;
}
// getting id of the returned function
returnFunction().id
但我不清楚這個目標......
添加回答
舉報