🏟️ BUIDL where legends play. Join our Hackathon at Parc des Princes, Paris – July 2025 •
Register Now
Chiliz Chain Developer Docs
Chiliz ChainBlock ExplorerCommunitySocios.com
Português do Brasil
Português do Brasil
  • Documentação para desenvolvedores da Chiliz Chain
  • Início Rápido
    • Chiliz Chain em poucas palavras
    • Conectar-se ao Mainnet e Testnet
    • Obtenha tokens de testnet
      • Obtenha testCHZs com o Faucet da Tatum
    • Implantar e verificar um contrato
      • Implantar com Remix IDE
        • Contrato inteligente ERC-20
      • Implantar com thirdweb
      • Verificar com Chiliscan
      • Verificar com Chiliz Block Explorer
    • Executar um Nó da Chiliz Chain
    • Curso online gratuito
    • Endereços de Alocação de Suprimento Inflacionário
  • Aprender
    • Sobre a Chiliz Chain
      • 2024 Dragon8 hard fork
      • Chiliz Labs
    • Chiliz Bridge
      • Como fazer a bridge dos seus CHZ
    • Staking na Chiliz Chain
      • Faça Stake do seu CHZ
      • Desfazer o Stake do seu CHZ
      • Recompensas de Staking
      • Fazendo Staking de CHZ com sua Ledger
    • Torne-se um Validador
      • Executar um Nó de Validador
      • Slashing de Validadores
  • Desenvolver
    • Básico
      • Use MetaMask
        • Instalar MetaMask
        • Conectar Chiliz Chain ao MetaMask
      • Conectar à Chiliz Chain
        • Conectar usando RPC
        • Executar um Nó da Chiliz Chain
        • Use uma carteira de hardware
      • Block Explorers
      • Spicy Faucets
        • Obtenha testCHZs com o Faucet da Tatum
        • Obtenha testCHZs com o Spicy Faucet
        • Obtenha Fan Tokens de teste com o Spicy Faucet
    • Avançado
      • Como usar Account Abstraction
      • Como usar um Oracle
      • Como usar um RNG
Powered by GitBook
On this page
  • Crie seu próprio token
  • Contrato inteligente ERC-20

Was this helpful?

  1. Início Rápido
  2. Implantar e verificar um contrato
  3. Implantar com Remix IDE

Contrato inteligente ERC-20

Customise and use the ERC-20 smart contract to create a token

Crie seu próprio token

Como uma prática recomendada, você pode optar por criar seu próprio token usando o modelo padrão ERC-20.

Use o seguinte contrato inteligente no editor de código de sua escolha, personalize sua criptomoeda e compile seu código após aprovar a conexão usando sua carteira digital preferida (aqui, usamos a MetaMask Wallet).

Contrato inteligente ERC-20

// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.16;

interface IERC20 {
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address to, uint256 amount) external returns (bool);
    function allowance(address owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(address from, address to, uint256 amount) external returns (bool);
}

contract SampleERC20Token is IERC20 {
    string public symbol;
    string public  name;
    uint8 public decimals;
    uint public _totalSupply;
    mapping(address => uint) balances;
    mapping(address => mapping(address => uint)) allowed;

    constructor() {
        symbol = "SYM";
        name = "Sample ERC20 Token";
        decimals = 2;
        _totalSupply = 100000;
        balances[msg.sender] = _totalSupply;
        emit Transfer(address(0), msg.sender, _totalSupply);
    }
    function totalSupply() external view returns (uint) {
        return _totalSupply  - balances[address(0)];
    }
    function balanceOf(address tokenOwner) external view returns (uint balance) {
        return balances[tokenOwner];
    }
    function transfer(address to, uint tokens) public returns (bool success) {
        balances[msg.sender] = balances[msg.sender] - tokens;
        balances[to] = balances[to] + tokens;
        emit Transfer(msg.sender, to, tokens);
        return true;
    }
    function approve(address spender, uint tokens) public returns (bool success) {
        allowed[msg.sender][spender] = tokens;
        emit Approval(msg.sender, spender, tokens);
        return true;
    }
    function transferFrom(address from, address to, uint tokens) public returns (bool success) {
        balances[from] = balances[from] - tokens;
        allowed[from][msg.sender] = allowed[from][msg.sender] - tokens;
        balances[to] = balances[to] + tokens;
        emit Transfer(from, to, tokens);
        return true;
    }
    function allowance(address tokenOwner, address spender) external view returns (uint remaining) {
        return allowed[tokenOwner][spender];
    }
}

Last updated 11 months ago

Was this helpful?