You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

3.3 KiB

Tips

Transfers

For users, it is more gas optimal to transfer bulk minted tokens in ascending token ID order.

For example, if you have bulk minted token IDs (33, 34, ..., 99),
you should transfer in the order (33, 34, ..., 99).

This is due to how the lazy-initialization mechanism works internally:
it scans uninitialized slots in descending order until it finds an initialized slot.

Popularity

The more popular your NFT collection, the larger the expected savings in transaction fees.

See Design: Lower Fees.

Aux

Consider using ERC721A._getAux and ERC721A._setAux to get / set per-address variables
(e.g. number of whitelist mints per address).

This can help remove an extra cold SLOAD and SSTORE operation.

Minting

For typical artwork collections, consider using _mint over _safeMint if you don't expect users to mint to contracts.

Batch Size

During transfers, ERC721A scans through ownership storage slots until it finds an initialized slot.

To prevent expensive first-time transfer fees for tokens minted in large batches, either:

  • Restrict the max batch size for public mints to a reasonable number.

  • Break up excessively large batches into mini batches internally when minting.

  • Use _initializeOwnershipAt every couple tokens to reduce number of reads during a transfer.

Efficient Tokenomics

ERC721A keeps track of additional variables in the internal mappings.

These variables hitchhike on the SLOADs and SSTOREs at near zero additional gas cost (< 1%).

You can use them to design tokenomics with very minimal gas overhead.

The startTimestamp, is available via the TokenOwnership struct.

You can get it from the _ownershipOf function or the non-reverting ERC721AQueryable.explicitOwnershipOf function.

ERC721A vs ERC1155

ERC721A ERC1155
O(1) ownerOf Yes No ownerOf
O(1) balanceOf For all tokens Within fungible tokens
O(1)* bulk mint For all tokens Within fungible tokens
# mint SSTOREs 3 1

* Approximately O(1) for ERC721A. See Design.

For unique collections, ERC1155 needs a counter which needs 1 more SSTORE.

ERC1155 requires centralized indexing services to emulate ERC721-like functionality off-chain.

Other Implementations

ERC721A is not a one-size-fits-all solution.

It is heavily optimized for generative artwork NFT collections.

If your collection does not expect a busy mint phase (e.g. a pure utility NFT),
or does not require bulk minting,
these excellent implementations can be better for lowering overall transaction fees:

Use the right tool for the job.