合约交易中transfer和send的区别

send()成员函数
addr.transfer(eth) 等价于 require(addr.send(eth))

推荐用transfer,因为有报错提示
send错了,因为默认不报错,所以用断言
assert(towho.send(1 ether));

// transfer()成员函数

// 说明:接收币的合约,必须有fallback函数,0.6以上版本还增加了receive函数
// funtion () public payable{
// }

// 0.6以上版本有函数名
// receive() external payable {
//        data = "receive call";
//    }

//    fallback() external payable {
//        data = "fallback call";
//    }


pragma solidity ^0.4.0;

contract Called{
    event logdata(bytes data);
    function ()  view returns (uint) foo;

    // 这是一个回退函数, 收到以太币会被调用
    function() public payable {
      emit logdata(msg.data); // 调用日志
    }

    function getBalance() public view returns (uint) {
        return this.balance;
    }
     

}

contract CallTest{

    constructor() public payable {
    }

    function transferEther(address towho) public returns (bool) {
        towho.transfer(1 ether);
        // assert(towho.send(1 ether));  // 因为默认不报错,所以用断言
        return true;
    }
    function getBalance() public view returns (uint){
        return this.balance;
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,以下是使用TronWeb库并编写HTML界面来调用TRC20合约transfer函数进行USDT转账的示例代码: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>TRC20 USDT转账</title> </head> <body> <h1>TRC20 USDT转账</h1> <div> <p>发送地址:</p> <input type="text" id="fromAddress"> </div> <div> <p>发送地址私钥:</p> <input type="password" id="privateKey"> </div> <div> <p>接收地址:</p> <input type="text" id="toAddress"> </div> <div> <p>发送数量:</p> <input type="number" id="amount"> </div> <div> <button onclick="transfer()">转账</button> </div> <script src="https://cdn.jsdelivr.net/npm/tronweb@3.6.5/dist/tronweb.js"></script> <script> async function transfer() { const tronWeb = new TronWeb({ fullHost: 'https://api.trongrid.io' }); const usdtContractAddress = 'TRC20 USDT合约地址'; const usdtContract = await tronWeb.contract().at(usdtContractAddress); const fromAddress = document.getElementById('fromAddress').value; const privateKey = document.getElementById('privateKey').value; const toAddress = document.getElementById('toAddress').value; const amount = document.getElementById('amount').value; // 将USDT数量转换为最小单位 const usdtAmount = amount * 1000000; const transaction = await usdtContract.transfer(toAddress, usdtAmount).send({ feeLimit: 1000000, callValue: 0, shouldPollResponse: true }, privateKey); console.log(transaction); } </script> </body> </html> ``` 在上面的代码,您需要将`TRC20 USDT合约地址`替换为您要使用的USDT合约的地址。在HTML界面,我们使用`<input>`元素来获取发送地址、发送地址私钥、接收地址和发送数量,并使用`<button>`元素来触发调用TRC20合约transfer函数进行USDT转账的操作。 请注意,在实际使用,您应该将私钥存储在安全的地方,并使用其他更安全的方式来获取私钥,比如使用硬件钱包。此外,您还应该对用户输入进行验证,以确保输入的数据符合要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端段

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值