uniapp 接入web3js

1 篇文章 0 订阅

在模板文件index.html里引入web3js;也可以通过npm i web3 ;还有把文件下载到项目中 import web3 from ‘x/web3.min.js’; 这里博主是在index.html里引入

在这里插入图片描述

  • template.h5.html
<!DOCTYPE html>
<html lang="zh-CN">
	<head>
		<meta charset="utf-8">
		<meta http-equiv="X-UA-Compatible" content="IE=edge">
		<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, viewport-fit=cover">
		<title>
			<%= htmlWebpackPlugin.options.title %>
		</title>
		<link rel="icon" href="./static/logo1.png" />
		//引入web3  1.5.5版本的
		<script src="https://cdn.bootcdn.net/ajax/libs/web3/1.3.5/web3.min.js" type="text/javascript" charset="utf-8"></script>
		<script>
			window.addEventListener('load', async function () {
			    // 检查web3是否已经注入到(Mist/MetaMask)
			    if (typeof web3 !== 'undefined') {
			        // 使用 Mist/MetaMask 的提供者
			        web3js = new Web3(web3.currentProvider);
			    } else {
			        // 开发环境,如果在本地有以太坊的testrpc或者Ganache测试环境,则使用以下方式链接
			        web3js = new Web3(new Web3.providers.HttpProvider("http://localhost:8545"));
			      }
			    console.log('现在你可以启动你的应用并自由访问 Web3.js')
			})
		</script>
	
        <style>
            ::-webkit-scrollbar{
                display: none;
            }
        </style>
		<script>
			document.addEventListener('DOMContentLoaded', function() {
				document.documentElement.style.fontSize = document.documentElement.clientWidth / 20 + 'px'
			})
		</script>
		<link rel="stylesheet" href="<%= BASE_URL %>static/index.<%= VUE_APP_INDEX_CSS_HASH %>.css" />
	</head>
	<body>
		<noscript>
			<strong>Please enable JavaScript to continue.</strong>
		</noscript>
		<div id="app"></div>
		<script>
			/*BAIDU_STAT*/
		</script>
	</body>
</html>

  • 开始使用
// 授权
async handleUserAuth(){
try{
		const userAddress = await ethereum.request({ method: 'eth_requestAccounts' });
		//调用者的钱包地址
		console.log('userAddress',userAddress)
	}catch(err){
		uni.showToast({
			title:err.message,
			icon:'none'
		})
	}
},

//获取余额
async handleBalanceTap(){
	//获取钱包地址
	const accounts = await web3js.eth.getAccounts();
		//获取钱包里的余额
		const balance = await web3js.eth.getBalance(accounts[0]);
		//格式化钱包余额为正常显示金额
		const fromWei = await web3js.utils.fromWei(balance, 'ether');
		console.log('我的余额',parseFloat(fromWei).toFixed(4))
},
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值