DAPP實戰篇:使用web3.js連接合約

說明

本系列內容目錄:專欄:區塊鏈入門到放棄查看目錄

如果你還沒有創建好項目請先查看:《DApp實戰篇:先用前端起個項目》,如果你還不知道web3.js是什么請先查看:《DApp實戰篇:前端技術棧一覽》。

安裝

點此查看web3.js官方文檔

打開項目根目錄,并喚起終端:

鍵入web3.js安裝命令:

npm install web3

之后回車安裝即可。

再運行項目:

運行成功后會在瀏覽器中默認打開項目,如下:

開始開發

為了方便調試和可視化,我們先在頁面上寫一個連接合約按鈕,代碼如下:

<template><q-page class="flex flex-center"><q-btn color="primary" label="點擊連接合約"></q-btn></q-page>
</template><script setup>
//
</script>

運行效果如下:

按鈕思路

現在我們需要完成的是點擊按鈕就實現合約連接,如果報錯則顯示在按鈕下面,如果連接成功則則按鈕上面顯示個連接成功。

修改UI

<template><q-page class="flex flex-center"><q-card class="text-center main-card"><q-card-section class="text-positive"><q-icon name="check" size="4em"></q-icon><h5 class="text-h5 font-weight-bold">連接成功</h5></q-card-section><q-card-section><q-btn size="lg" glossy push color="primary" label="點擊連接合約"></q-btn></q-card-section><q-card-section class="text-small text-negative"> 連接失敗,錯誤原因: </q-card-section></q-card></q-page>
</template><script>
import { defineComponent } from 'vue'
export default defineComponent({name: 'IndexPage',
})
</script>
<style>
.main-card {width: 450px;
}
</style>

運行如圖:

定義兩個變量來控制顯示

目前我們的所有元素都是全部顯示的,我們要實現的應該是如果連接成功則顯示連接成功和隱藏按鈕,如果連接失敗則顯示連接失敗以及錯誤原因,因此再改一下:

<template><q-page class="flex flex-center"><q-card class="text-center main-card"><q-card-section class="text-positive" v-if="isConnected"><q-icon name="check" size="4em"></q-icon><h5 class="text-h5 font-weight-bold">連接成功</h5></q-card-section><q-card-section v-if="!isConnected"><q-btn size="lg" glossy push color="primary" label="點擊連接合約"></q-btn></q-card-section><q-card-section class="text-small text-negative" v-if="errorMessage !== ''">連接失敗,錯誤原因:</q-card-section></q-card></q-page>
</template><script>
import { defineComponent } from 'vue'
export default defineComponent({name: 'IndexPage',data: function () {return {isConnected: false, //是否連接成功errorMessage: '', //是否報錯}},
})
</script>
<style>
.main-card {width: 450px;
}
</style>

修改完成運行如圖:

連接合約

我們先定義一個連接合約的函數,并將其綁定到按鈕上:

<template><q-page class="flex flex-center"><q-card class="text-center main-card"><q-card-section class="text-positive" v-if="isConnected"><q-icon name="check" size="4em"></q-icon><h5 class="text-h5 font-weight-bold">連接成功</h5></q-card-section><q-card-section v-if="!isConnected"><!-- 點擊連接 --><q-btn @click="connect" size="lg" glossy push color="primary" label="點擊連接合約"></q-btn></q-card-section><q-card-section class="text-small text-negative" v-if="errorMessage !== ''">連接失敗,錯誤原因:</q-card-section></q-card></q-page>
</template><script>
import { defineComponent } from 'vue'
export default defineComponent({name: 'IndexPage',data: function () {return {isConnected: false, //是否連接成功errorMessage: '', //是否報錯}},methods: {// 定義連接函數connect: function () {},},
})
</script>
<style>
.main-card {width: 450px;
}
</style>

之后開始編碼連接:

web3方法:

new web3.eth.Contract(jsonInterface[, address][, options])

1.jsonInterface

ABI對象:至于什么是abi可以查看《基礎知識補充篇:認識智能合約的ABI》。

2.address

合約地址。

3.options

其他參數,目前用不到。

連接USDT合約

點此前往區塊鏈瀏覽器查看合約

這里我們連接eth鏈的usdt合約,參數如下:

address:0xdac17f958d2ee523a2206206994597c13d831ec7

abi json 如下:

[{"constant": true,"inputs": [],"name": "name","outputs": [{"name": "","type": "string"}],"payable": false,"stateMutability": "view","type": "function"},{"constant": false,"inputs": [{"name": "_upgradedAddress","type": "address"}],"name": "deprecate","outputs": [],"payable": false,"stateMutability": "nonpayable","type": "function"},{"constant": false,"inputs": [{

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/76164.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/76164.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/76164.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

源代碼保密解決方案

背景分析 隨著各行各業業務數據信息化發展&#xff0c;各類產品研發及設計等行業&#xff0c;都有關乎自身發展的核心數據&#xff0c;包括業務數據、源代碼保密數據、機密文檔、用戶數據等敏感信息&#xff0c;這些信息數據有以下共性&#xff1a; — 屬于核心機密資料&…

dolphinscheduler單機部署鏈接oracle

部署成功請給小編一個贊或者收藏激勵小編 1、安裝準備 JDK版本:1.8或者1.8oracle版本&#xff1a;19Coracle驅動版本&#xff1a;8 2、安裝jdk 下載地址&#xff1a;https://www.oracle.com/java/technologies/downloads/#java8 下載后上傳到/tmp目錄下。 然后執行下面命…

2025-04-08 NO.4 Quest3 交互教程

文章目錄 1 環境準備2 新手指引&#xff1a;Building Blocks2.1 創建 OVR 相機2.2 創建交互功能2.3 創建交互物體 3 老手開發&#xff1a;Interaction SDK3.1 創建交互功能3.2 創建交互物體 4 UI 交互4.1 3D 按鈕4.2 Unity UI ? 新版 Meta SDK&#xff08;v74&#xff09;優化…

關于Spring MVC中@RequestMapping注解的詳細解析,涵蓋其核心功能、屬性、使用場景及最佳實踐

以下是關于Spring MVC中RequestMapping注解的詳細解析&#xff0c;涵蓋其核心功能、屬性、使用場景及最佳實踐&#xff1a; 1. 基礎概念 RequestMapping是Spring MVC的核心注解&#xff0c;用于將HTTP請求映射到控制器&#xff08;Controller&#xff09;的方法上。它支持類級…

Scala 異常處理

Scala 異常處理 引言 Scala 是一門多范式編程語言,它結合了面向對象和函數式編程的特性。在軟件開發過程中,異常處理是保證程序穩定性和可靠性的重要環節。本文將深入探討 Scala 中的異常處理機制,包括異常的拋出、捕獲和處理策略。 異常概述 什么是異常? 在計算機編程…

PyTorch:解鎖AI新時代的鑰匙

&#xff08;前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到網站&#xff09;。 揭開PyTorch面紗 對于許多剛開始接觸人工智能領域的朋友來說&#xff0c;PyTorch這個名字或許既熟悉又陌生。…

React-06React中refs屬性(字符串refs,回調形式,React.createRef() )

1.React中refs屬性 綁定到render輸出的任何組件上&#xff0c;通過this.ref.綁定名直接操作DOM元素或獲取子組件的實例。 2.綁定refs實例 2.1 字符串refs(已經過時參考官網API) 字符串(string)的ref存在一定的效率問題 <input refinput1 type"text" placehole…

五子棋游戲開發:靜態資源的重要性與設計思路

以下是以CSDN博客的形式整理的關于五子棋游戲靜態資源需求的文章&#xff0c;基于我們之前的討論&#xff0c;內容結構清晰&#xff0c;適合開發者閱讀和參考。我盡量保持技術性、實用性&#xff0c;同時加入一些吸引讀者的亮點。 五子棋游戲開發&#xff1a;靜態資源的重要性與…

c編譯和c++編譯有什么區別?

文章目錄 c編譯和c編譯有什么區別多態函數重載虛函數表 vtable 輸入輸出同步類型檢查模板和特化鏈接 C 標準庫 C 能編譯 C 的代碼嗎&#xff1f; c編譯和c編譯有什么區別 多態 函數重載 C 支持多個同名函數&#xff08;參數不同&#xff09;&#xff0c;這是編譯期多態 編譯…

無縫集成Docker與Maven:docker-maven-plugin實戰指南

關于 docker-maven-plugin 的詳細介紹和使用指南&#xff0c;幫助你在 Maven 項目中實現 Docker 鏡像的自動化構建、推送和管理。 1. 插件的作用 docker-maven-plugin 是一個 Maven 插件&#xff0c;允許在 Maven 構建生命周期中直接集成 Docker 操作&#xff0c;例如&#xf…

智能倉儲數字孿生Demo(Unity實現)

一、項目背景與行業痛點 醫藥流通行業倉儲管理面臨三大核心挑戰&#xff1a; 合規性風險&#xff1a;GSP&#xff08;藥品經營質量管理規范&#xff09;對溫濕度、藥品批次追溯的嚴苛要求&#xff0c;傳統人工記錄易出錯效率瓶頸&#xff1a;庫區布局復雜&#xff0c;人工巡檢…

詳解 Go 的常見環境變量及其在 zshrc 中的配置

Go 語言作為一門現代化的編程語言&#xff0c;其編譯、構建和包管理等環節都依賴于一系列環境變量的配置。正確理解和設置這些環境變量&#xff0c;對于 Go 開發至關重要。本文將詳細介紹 Go 的常見環境變量&#xff0c;并解釋如何將其配置到 zshrc 文件中&#xff0c;以方便日…

【NLP 55、強化學習與NLP】

萬事開頭難&#xff0c;苦盡便是甜 —— 25.4.8 一、什么是強化學習 強化學習和有監督學習是機器學習中的兩種不同的學習范式 強化學習&#xff1a;目標是讓智能體通過與環境的交互&#xff0c;學習到一個最優策略以最大化長期累積獎勵。 不告訴具體路線&#xff0c;首先去做…

Java 面試系列:Java 中的運算符和流程控制 + 面試題

算術運算符 Java 中的算術運算符&#xff0c;包括以下幾種&#xff1a; 算術運算符名稱舉例加法123-減法2-11*乘法2*36/除法24/83%求余24%73自增1int i1;i--自減1int i1;i-- 我們本講要重點講的是 “” 和 “--”&#xff0c;其他的算術運算符相對比較簡單直觀&#xff0c;本講…

硅谷甄選項目筆記

硅谷甄選運營平臺 此次教學課程為硅谷甄選運營平臺項目,包含運營平臺項目模板從0到1開發&#xff0c;以及數據大屏幕、權限等業務。 此次教學課程涉及到技術棧包含***:vue3TypeScriptvue-routerpiniaelement-plusaxiosecharts***等技術棧。 一、vue3組件通信方式 通信倉庫地…

zk基礎—zk實現分布式功能

1.zk實現數據發布訂閱 (1)發布訂閱系統一般有推模式和拉模式 推模式&#xff1a;服務端主動將更新的數據發送給所有訂閱的客戶端。 拉模式&#xff1a;客戶端主動發起請求來獲取最新數據(定時輪詢拉取)。 (2)zk采用了推拉相結合來實現發布訂閱 首先客戶端需要向服務端注冊自己關…

大坑!GaussDB數據庫批量插入數據變只讀

大坑!GaussDB數據庫批量插入數據變只讀 GaussDB插入數據時變只讀df和du為什么不一致GaussDB磁盤空間使用閾值GaussDB變只讀怎么辦正確刪除表的姿勢GaussDB插入數據時變只讀 涉及的數據庫版本為:GaussDB Kernel 505.1.0 build da28c417。 GuassDB TPCC灌數報錯DML失敗,數據…

動態規劃算法深度解析:0-1背包問題(含完整流程)

簡介&#xff1a; 0-1背包問題是經典的組合優化問題&#xff1a;給定一組物品&#xff08;每個物品有重量和價值&#xff09;&#xff0c;在背包容量限制下選擇物品裝入背包&#xff0c;要求總價值最大化且每個物品不可重復選取。 動態規劃核心思想 通過構建二維狀態表dp[i]…

ABAP,PDF,ADS,FORM,PRINT

ABAP怎么直接打印PDF文件? https://faskomyabap.blogspot.com/2017/10/how-to-print-pdf-file-content-from-abap.html 里面的程序可以直接將本地文件打印出來,讀一下過程,這個程序是把本地PDF文件使用upload函數到ABAP中,先是二進制,然后轉成XSTRING,然后使用 連招 ADS…

C++Cherno 學習筆記day17 [66]-[70] 類型雙關、聯合體、虛析構函數、類型轉換、條件與操作斷點

b站Cherno的課[66]-[70] 一、C的類型雙關二、C的union&#xff08;聯合體、共用體&#xff09;三、C的虛析構函數四、C的類型轉換五、條件與操作斷點——VisualStudio小技巧 一、C的類型雙關 作用&#xff1a;在C中繞過類型系統 C是強類型語言 有一個類型系統&#xff0c;不…