我试图将以下数字传递给标准的approve()令牌契约的ERC20函数:
2^256-1我读到,这应该使用BigNumber来完成,使用以下代码:
const maxInt = new BN("2").pow(new BN("256").sub(new BN("1")));
// Will pass into solidity as uint 2**256 - 1嗯,我在使用这段代码时遇到了各种各样的错误--首先,BigNumber的语法和命令看起来非常不同,取决于您使用的是哪个版本的ethers --而我碰巧使用的是V.4.0--为了避免其他潜在的麻烦,我非常希望现在就继续使用它。
因此,我尝试了上述代码的各种变体--这里有一个,我把公式的每个组成部分分解成它自己的部分--只是为了看看怎么回事:
// ==>Using 'bigNumberify'
let bigNum2 = ethers.utils.bigNumberify("2");
console.log("'bigNum2' -> '2' = ", bigNum2);
let bigNum256 = ethers.utils.bigNumberify("256");
console.log("'bigNum256' -> '256' = ", bigNum256);
let bigNum2power256 = ethers.utils.bigNumberify(bigNum2.pow(bigNum256));
console.log("'bigNum2power256' -> 2^256= ", bigNum2power256);
let bigNum1 = ethers.utils.bigNumberify("1");
console.log("'bigNum1' -> '1' = ", bigNum1);
let finalNumber = ethers.utils.bigNumberify(bigNum2power256 - bigNum1);
console.log("'finalNumber' = ", finalNumber);当我将这个finalNumber传递给approve()时,我会得到以下错误:
Uncaught (in promise) Error: underflow (operation="setValue", fault="underflow", value=1.157920892373162e+77, outputValue=1, version=4.0.45)我尝试过对这段代码进行各种不同的修改--比如替换这一行:
let bigNum2power256 = ethers.utils.bigNumberify(bigNum2.pow(bigNum256));通过以下方式:
let bigNum2power256 = bigNum1.pow(bigNum2);但这也行不通。
我尝试过的每一个变体--而且有很多--似乎给了我另一种错误--为什么这很难呢?怎么做才是对的?
=========================
为了明确起见,2^256-1的值--我将其存储在bigNum2power256变量中,最终需要被传入--作为以下契约函数调用的第二个参数:
tokenContractInstance.approve(contractAddress, bigNum2power256, { gasLimit: 500_000 }).then((txResult) => {
console.log("Back from 'tokenContractInstance' 'approve'");
console.log(">Here's the 'approve' txResult = \n", txResult);
.....
}发布于 2022-09-11 02:14:26
如果使用的是ethers.js,则可以直接使用一个常量模块:这里
const maxNumber = ethers.constants.MaxUint256https://ethereum.stackexchange.com/questions/135384
复制相似问题