搜尋
首頁web前端js教程簡介。使用 JavaScript Web建立 Cardano 錢包檢查器。

這個專案是我的第一個 Web3 應用程序,它透過 Yoroi 錢包連接到 Cardano 區塊鏈。實際上,這非常簡單,只是檢查錢包餘額的一種方法,但它標誌著許多令人興奮的項目的開始。我想在學習本教程時與您分享我的學習過程。

?我們正在建設什麼?

在開始之前,讓我們先明確一下我們正在創建什麼。這是一個簡單的工具,可以讓您:

  • 查看任何卡爾達諾錢包的餘額(當然是合法的!?)
  • 連接到您的 Yoroi 錢包
  • 在 ADA 中顯示餘額

Intro. to WebBuilding a Cardano Wallet Checker with JavaScript.

?你需要什麼

基本的 JavaScript 知識(如果你會 console.log("hello world"),就很好了!)

  1. - 文字編輯器(VS Code、Sublime,如果您喜歡冒險,甚至可以使用記事本)
  2. - Yoroi 錢包擴充已安裝(我們需要它進行測試)
  3. - Blockfrost API 金鑰(別擔心,我將向您展示如何取得它) 讓我們開始吧!

第 1 步:設定項目

在電腦上建立一個名為 CardanoWalletExplorer 的新資料夾(如果您願意,也可以是 junky justyk,名稱並不重要)。在程式碼編輯器中開啟該資料夾(我使用 Visual Studio Code)。
在資料夾內,建立兩個檔案:
index.html 和 style.css
現在打開index.html並貼上以下內容:



    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Cardano Wallet Explorer</title>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap" rel="stylesheet">
    <link rel="stylesheet" href="style.css">


    <div>



<p>Let's add some style to our creation. Inside the style.css file paste this in:<br>
</p>

<pre class="brush:php;toolbar:false">:root {
    --primary-color: #0033ad;
    --secondary-color: #2a71d4;
    --accent-color: #17d1aa;
    --background-color: #f8faff;
    --card-background: #ffffff;
    --text-primary: #1a202c;
    --text-secondary: #4a5568;
    --border-color: #e2e8f0;
    --shadow: 0 4px 6px rgba(0,0,0,0.1);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Inter', system-ui, sans-serif;
    background: var(--background-color);
    color: var(--text-primary);
    line-height: 1.5;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem;
}

.container {
    background: var(--card-background);
    border-radius: 1.5rem;
    box-shadow: var(--shadow);
    width: 100%;
    max-width: 800px;
    overflow: hidden;
}

.app-header {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    padding: 2rem;
    text-align: center;
}

.logo {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 0.5rem;
}

.logo i { font-size: 2rem; }
h1 { font-size: 1.8rem; font-weight: 600; }
.subtitle { opacity: 0.9; }

.content { padding: 2rem; }

.search-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.search-box {
    display: flex;
    gap: 1rem;
    width: 100%;
    max-width: 600px;
}

#wallet-search {
    flex: 1;
    padding: 0.875rem 1rem;
    border: 2px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.95rem;
    transition: 0.3s ease;
}

#wallet-search:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(23, 209, 170, 0.1);
}

button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    border: none;
    border-radius: 12px;
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    transition: 0.3s ease;
}

#search-button {
    background: var(--accent-color);
    color: white;
}

#search-button:hover {
    background: #15bea0;
    transform: translateY(-2px);
}

.divider {
    width: 100%;
    max-width: 600px;
    text-align: center;
    position: relative;
    color: var(--text-secondary);
}

.divider::before,
.divider::after {
    content: '';
    position: absolute;
    top: 50%;
    width: calc(50% - 2rem);
    height: 1px;
    background: var(--border-color);
}

.divider::before { left: 0; }
.divider::after { right: 0; }

.connect-button {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    padding: 1rem 2rem;
}

.connect-button:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

.wallet-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}

.info-card {
    background: var(--card-background);
    border: 1px solid var(--border-color);
    border-radius: 1rem;
    padding: 1.5rem;
    transition: 0.3s ease;
}

.info-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

.card-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
    color: var(--text-secondary);
}

.card-header i {
    font-size: 1.25rem;
    color: var(--primary-color);
}

.card-content {
    font-size: 0.95rem;
    color: var(--text-primary);
    word-break: break-all;
}

.app-footer {
    text-align: center;
    padding: 1.5rem;
    background: var(--background-color);
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.app-footer a {
    color: var(--primary-color);
    text-decoration: none;
}

.app-footer a:hover {
    text-decoration: underline;
}

@media (max-width: 640px) {
    body {
        padding: 1rem;
    }

    .container {
        border-radius: 1.5rem;
    }

    .app-header {
        padding: 1.5rem;
    }

    .content {
        padding: 1.5rem;
    }

    .search-box {
        flex-direction: column;
    }

    button {
        width: 100%;
        justify-content: center;
    }

    .wallet-info {
        grid-template-columns: 1fr;
    }
}

步驟 2:如何取得您的 Blockfrost API 金鑰?

為了取得錢包餘額,我們需要 Blockfrost,它允許我們與 Cardano 區塊鏈進行互動。以下是取得 API 金鑰的方法:

  • 前往 Blockfrost.io 並註冊。
  • 登入後,點選「建立新項目」。
  • 選擇主網進行真正的 ADA 或選擇測試網進行測試。
  • 專案建立後,您將獲得一個API Key。

第三步:手術的大腦?

現在到了有趣的部分,讓它一切正常!在我們創建的資料夾中建立一個名為 script.js 的檔案。

function checkYoroiInstalled() {
    return window.cardano && window.cardano.yoroi;
}

?此功能檢查您的瀏覽器中是否安裝了 Yoroi 錢包擴充功能。 Window.cardano 是像 Yoroi 這樣的 Cardano 錢包公開的物件。我們檢查它是否存在以及 window.cardano.yoroi 是否可用於確認 Yoroi 錢包已安裝。
如果兩者都為 true,則函數傳回 true;否則,傳回 false。



    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Cardano Wallet Explorer</title>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap" rel="stylesheet">
    <link rel="stylesheet" href="style.css">


    <div>



<p>Let's add some style to our creation. Inside the style.css file paste this in:<br>
</p>

<pre class="brush:php;toolbar:false">:root {
    --primary-color: #0033ad;
    --secondary-color: #2a71d4;
    --accent-color: #17d1aa;
    --background-color: #f8faff;
    --card-background: #ffffff;
    --text-primary: #1a202c;
    --text-secondary: #4a5568;
    --border-color: #e2e8f0;
    --shadow: 0 4px 6px rgba(0,0,0,0.1);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Inter', system-ui, sans-serif;
    background: var(--background-color);
    color: var(--text-primary);
    line-height: 1.5;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2rem;
}

.container {
    background: var(--card-background);
    border-radius: 1.5rem;
    box-shadow: var(--shadow);
    width: 100%;
    max-width: 800px;
    overflow: hidden;
}

.app-header {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    padding: 2rem;
    text-align: center;
}

.logo {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 0.5rem;
}

.logo i { font-size: 2rem; }
h1 { font-size: 1.8rem; font-weight: 600; }
.subtitle { opacity: 0.9; }

.content { padding: 2rem; }

.search-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.search-box {
    display: flex;
    gap: 1rem;
    width: 100%;
    max-width: 600px;
}

#wallet-search {
    flex: 1;
    padding: 0.875rem 1rem;
    border: 2px solid var(--border-color);
    border-radius: 12px;
    font-size: 0.95rem;
    transition: 0.3s ease;
}

#wallet-search:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(23, 209, 170, 0.1);
}

button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    border: none;
    border-radius: 12px;
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    transition: 0.3s ease;
}

#search-button {
    background: var(--accent-color);
    color: white;
}

#search-button:hover {
    background: #15bea0;
    transform: translateY(-2px);
}

.divider {
    width: 100%;
    max-width: 600px;
    text-align: center;
    position: relative;
    color: var(--text-secondary);
}

.divider::before,
.divider::after {
    content: '';
    position: absolute;
    top: 50%;
    width: calc(50% - 2rem);
    height: 1px;
    background: var(--border-color);
}

.divider::before { left: 0; }
.divider::after { right: 0; }

.connect-button {
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    color: white;
    padding: 1rem 2rem;
}

.connect-button:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

.wallet-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
    margin-top: 2rem;
}

.info-card {
    background: var(--card-background);
    border: 1px solid var(--border-color);
    border-radius: 1rem;
    padding: 1.5rem;
    transition: 0.3s ease;
}

.info-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

.card-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
    color: var(--text-secondary);
}

.card-header i {
    font-size: 1.25rem;
    color: var(--primary-color);
}

.card-content {
    font-size: 0.95rem;
    color: var(--text-primary);
    word-break: break-all;
}

.app-footer {
    text-align: center;
    padding: 1.5rem;
    background: var(--background-color);
    color: var(--text-secondary);
    font-size: 0.9rem;
}

.app-footer a {
    color: var(--primary-color);
    text-decoration: none;
}

.app-footer a:hover {
    text-decoration: underline;
}

@media (max-width: 640px) {
    body {
        padding: 1rem;
    }

    .container {
        border-radius: 1.5rem;
    }

    .app-header {
        padding: 1.5rem;
    }

    .content {
        padding: 1.5rem;
    }

    .search-box {
        flex-direction: column;
    }

    button {
        width: 100%;
        justify-content: center;
    }

    .wallet-info {
        grid-template-columns: 1fr;
    }
}

此函數以使用者友善的方式格式化 ADA 的餘額。
Cardano使用lovelace作為最小單位(1 ADA = 1,000,000 lovelace),所以我們需要將其除以1,000,000轉換為ADA。
它還確保餘額顯示為小數點後 6 位(例如 1.234567 ADA),或者如果餘額無效或為空,則傳回「0.000000」。

function checkYoroiInstalled() {
    return window.cardano && window.cardano.yoroi;
}

我們使用 Fetch API 向 Blockfrost 發出 GET 請求。 Blockfrost 提供了一個 API 來與 Cardano 區塊鏈互動。我們向特定錢包位址的端點發送 GET 請求,並使用 API 金鑰進行授權。該函數透過向 Blockfrost 的 API 發出請求來獲取特定錢包位址的餘額。

如果回應成功,我們將解析 JSON 資料並傳回該位址中 ADA 的數量。
如果發生錯誤(例如,無效位址或 API 問題),它將拋出錯誤並將其記錄到控制台。端點 URL 包括我們要檢查的錢包位址。確保將 checkWalletBalance 函數中的 YOUR_API_KEY 佔位符替換為您的 API 金鑰。

function formatBalance(lovelaceBalance) {
    if (!lovelaceBalance || isNaN(lovelaceBalance)) {
        return "0.000000";
    }
    const adaBalance = parseFloat(lovelaceBalance) / 1_000_000;
    return adaBalance.toFixed(6);
}

  • 此 UI 更新功能使用錢包位址和餘額更新使用者介面 (UI)。
  • 它會縮短地址以顯示前 8 個和後 8 個字元(以使其更具可讀性)並將其顯示在「錢包地址」卡中。
  • 它使用 formatBalance 函數格式化餘額並將其顯示在「錢包餘額」卡中。
  • 當您將滑鼠懸停在地址文字上時,它還會設定包含完整地址的工具提示。
**Fetching Wallet Balance Using Blockfrost API
async function checkWalletBalance(address) {
    try {
        const API_KEY = 'YOUR_API_KEY';
        const response = await fetch(`https://cardano-mainnet.blockfrost.io/api/v0/addresses/${address}`, {
            headers: {
                'project_id': API_KEY
            }
        });

        if (!response.ok) {
            throw new Error('Invalid address or API error');
        }

        const data = await response.json();
        return data.amount[0].quantity;
    } catch (error) {
        console.error('Error fetching balance:', error);
        throw error;
    }
}

此程式碼將事件偵聽器附加到 HTML 元素:
當點擊「連接 Yoroi Wallet」按鈕時,它會呼叫 connectWallet 函數。
當點擊「檢查餘額」按鈕時,它會呼叫handleWalletSearch函數。
如果使用者在錢包位址輸入欄中按下「Enter」鍵,也會觸發餘額檢查。

恭喜,你做到了! ?

您現在距離掌握 Web3 又更近了一步! ?這個專案不僅是一項技術成就,更是邁向區塊鏈開發廣闊世界的令人興奮的一步! ?
現在,您可以無縫連接到 Yoroi 錢包、檢查餘額,並將區塊鏈的力量帶到您的指尖。

?測試時間!

  1. 在 VS Code 上安裝 liveserver 擴展,並透過點擊「上線」按鈕確保其正在運行。
  2. 這應該會在您的瀏覽器中開啟 HTML 檔案
  3. 交叉手指並測試一下!

?您從這個專案中學到了什麼

  • 深入了解 Yoroi 等區塊鏈錢包如何運作以及如何與去中心化網路互動。
  • 掌握了使用 window.cardano API 將瀏覽器錢包安全地連接到網路應用程式的過程。
  • 探索了 Blockfrost API 以從 Cardano 區塊鏈獲取錢包餘額和地址詳細資訊。
  • 增強了非同步和等待、錯誤處理和資料格式化方面的知識,以確保流暢的使用者體驗。
  • 學會根據即時區塊鏈資料動態更新網頁元素。
  • 了解將加密貨幣單位從 Lovelace 轉換為 ADA 並格式化它們以供用戶閱讀的機制。
  • 認識到對 API 請求和使用者輸入進行穩健錯誤處理以防止中斷的重要性。
  • 獲得了對區塊鏈上的錢包結構、地址管理和交易表示的寶貴見解。
  • 實作了載入旋轉器、工具提示和警報等功能,以增強使用者互動。
  • 解決了邊緣情況和調試挑戰,加強了分析和編碼技能。

?升級的想法

這個專案是進入區塊鏈開發世界的墊腳石。以下是一些進一步推進的想法:

  • 新增交易歷史檢視器以顯示錢包位址過去的交易。
  • 實現多錢包支持,允許用戶在 Yoroi、Nami 或 Eternal 等錢包之間切換。
  • 建立一個顯示錢包活動趨勢的儀表板,包括傳入和傳出交易摘要。
  • 整合即時價格數據以顯示美元或歐元等法定貨幣的 ADA 餘額。
  • 透過整合交易建置功能,啟用直接從應用程式發送 ADA 的功能。
  • 添加深色模式切換,以獲得視覺上吸引人且易於訪問的設計。
  • 使介面響應式以確保與行動裝置的相容性。
  • 納入更好的錯誤訊息,引導使用者解決問題,例如無效的錢包地址。

?您如何做出貢獻

這個專案是我進入 Web3 的第一步,我渴望向最好的人學習。您的經驗、見解和建議可以使這個專案變得更好,同時也幫助我成長為開發人員。您可以透過以下方式做出貢獻:

  • 在 GitHub 上分叉該專案並添加新功能或改進。
  • 回報您在使用該工具時遇到的錯誤或問題並提出解決方案。
  • 透過在 GitHub 儲存庫上提出功能請求或討論來提出改進建議。
  • 為您新增的任何新功能編寫詳細文檔,以便其他人輕鬆使用和建置。

✨ 值得考慮的新功能

  • 添加二維碼支持,方便錢包位址共享和掃描。
  • 對餘額更新或交易確認等事件實施通知。
  • 包括一個教育部分,為初學者解釋區塊鏈基礎知識。
  • 引入遊戲化元素,例如頻繁使用錢包或探索新功能的成就。
  • 發展質押功能,顯示質押獎勵和委託狀態。

讓我們繼續建構和創新—您的貢獻和創造力可以塑造這個工具的未來! ?

?需要幫助嗎?

卡住了嗎?發現錯誤?想聊天嗎?在下面發表評論或在 Twitter 上找到我!
請記住,我們都是從某個地方開始的,唯一愚蠢的問題就是你沒有問的問題!

區塊鏈探索者們,編碼愉快! ?

以上是簡介。使用 JavaScript Web建立 Cardano 錢包檢查器。的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在JavaScript中替換字符串字符在JavaScript中替換字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

jQuery檢查日期是否有效jQuery檢查日期是否有效Mar 01, 2025 am 08:51 AM

簡單JavaScript函數用於檢查日期是否有效。 function isValidDate(s) { var bits = s.split('/'); var d = new Date(bits[2] '/' bits[1] '/' bits[0]); return !!(d && (d.getMonth() 1) == bits[1] && d.getDate() == Number(bits[0])); } //測試 var

jQuery獲取元素填充/保證金jQuery獲取元素填充/保證金Mar 01, 2025 am 08:53 AM

本文探討如何使用 jQuery 獲取和設置 DOM 元素的內邊距和外邊距值,特別是元素外邊距和內邊距的具體位置。雖然可以使用 CSS 設置元素的內邊距和外邊距,但獲取準確的值可能會比較棘手。 // 設定 $("div.header").css("margin","10px"); $("div.header").css("padding","10px"); 你可能會認為這段代碼很

10個jQuery手風琴選項卡10個jQuery手風琴選項卡Mar 01, 2025 am 01:34 AM

本文探討了十個特殊的jQuery選項卡和手風琴。 選項卡和手風琴之間的關鍵區別在於其內容面板的顯示和隱藏方式。讓我們深入研究這十個示例。 相關文章:10個jQuery選項卡插件

10值得檢查jQuery插件10值得檢查jQuery插件Mar 01, 2025 am 01:29 AM

發現十個傑出的jQuery插件,以提升您的網站的活力和視覺吸引力!這個精選的收藏品提供了不同的功能,從圖像動畫到交互式畫廊。讓我們探索這些強大的工具:相關文章:1

HTTP與節點和HTTP-Console調試HTTP與節點和HTTP-Console調試Mar 01, 2025 am 01:37 AM

HTTP-Console是一個節點模塊,可為您提供用於執行HTTP命令的命令行接口。不管您是否針對Web服務器,Web Serv

自定義Google搜索API設置教程自定義Google搜索API設置教程Mar 04, 2025 am 01:06 AM

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

jQuery添加捲軸到DivjQuery添加捲軸到DivMar 01, 2025 am 01:30 AM

當div內容超出容器元素區域時,以下jQuery代碼片段可用於添加滾動條。 (無演示,請直接複製到Firebug中) //D = document //W = window //$ = jQuery var contentArea = $(this), wintop = contentArea.scrollTop(), docheight = $(D).height(), winheight = $(W).height(), divheight = $('#c

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具