जावास्क्रिप्ट एपीआई पुस्तकालयों
पेज का अंतिम अपडेट: 25 फ़रवरी 2026
किसी वेब ऐप को एथेरियम ब्लॉकचेन के साथ इंटरैक्ट करने के लिए (यानी, ब्लॉकचेन डेटा पढ़ना और/या नेटवर्क पर लेनदेन भेजना), उसे एथेरियम नोड से कनेक्ट होना चाहिए।
इस उद्देश्य के लिए, हर एथेरियम क्लाइंट JSON-RPC विनिर्देश को लागू करता है, इसलिए विधियों का एक समान सेट है जिस पर एप्लिकेशन भरोसा कर सकते हैं।
यदि आप एथेरियम नोड से जुड़ने के लिए जावास्क्रिप्ट का उपयोग करना चाहते हैं, तो वेनिला जावास्क्रिप्ट का उपयोग करना संभव है लेकिन पारिस्थितिकी तंत्र के भीतर कई सुविधा पुस्तकालय मौजूद हैं जो इसे बहुत आसान बनाते हैं। इन पुस्तकालयों के साथ, डेवलपर्स एथेरियम के साथ बातचीत करने वाले JSON-RPC अनुरोधों (हुड के नीचे) को प्रारंभ करने के लिए सहज, एक-पंक्ति विधियां लिख सकते हैं।
कृपया ध्यान दें कि द मर्ज के बाद से, एथेरियम सॉफ्टवेयर के दो जुड़े हुए टुकड़े - एक निष्पादन क्लाइंट और एक सहमति क्लाइंट - को एक नोड चलाने के लिए आवश्यक हैं। कृपया सुनिश्चित करें कि आपके नोड में निष्पादन और सर्वसम्मति क्लाइंट दोनों शामिल हैं। यदि आपका नोड आपकी स्थानीय मशीन पर नहीं है (उदाहरण के लिए आपका नोड एडब्ल्यूएस इंस्टेंस पर चल रहा है) तो तदनुसार ट्यूटोरियल में आईपी पते अपडेट करें। अधिक जानकारी के लिए कृपया नोड चलाने पर हमारा पेज देखें।
पूर्वापेक्षाएं
जावास्क्रिप्ट को समझने के साथ-साथ, एथेरियम स्टैक और एथेरियम क्लाइंट्स को समझना भी सहायक हो सकता है।
पुस्तकालय का उपयोग क्यों करें?
ये पुस्तकालय एथेरियम नोड के साथ सीधे बातचीत करने की जटिलता को दूर करते हैं। वे यूटिलिटी फ़ंक्शन भी प्रदान करते हैं (जैसे, ETH को Gwei में बदलना) ताकि एक डेवलपर के रूप में आप एथेरियम क्लाइंट की जटिलताओं से निपटने में कम समय बिता सकें और अपने एप्लिकेशन की अनूठी कार्यक्षमता पर अधिक समय केंद्रित कर सकें।
लाइब्रेरी सुविधाएँ
एथेरियम नोड्स से कनेक्ट करें
प्रदाताओं का उपयोग करके, ये पुस्तकालय आपको एथेरियम से जुड़ने और इसके डेटा को पढ़ने की अनुमति देते हैं, चाहे वह JSON-RPC, INFURA, ETHERSCAN, कीमिया या मेटामास्क पर हो।
चेतावनी: वेब3.जेएस को 4 मार्च, 2025 को संग्रहीत किया गया था। घोषणा पढ़ें (opens in a new tab)। नई परियोजनाओं के लिए ethers.js (opens in a new tab) या viem (opens in a new tab) जैसी वैकल्पिक लाइब्रेरी का उपयोग करने पर विचार करें।
ईथर उदाहरण
1// एक BrowserProvider एक मानक Web3 प्रदाता को रैप करता है, जो है2// जो MetaMask हर पेज में window.ethereum के रूप में इंजेक्ट करता है3const provider = new ethers.BrowserProvider(window.ethereum)4
5// MetaMask प्लगइन लेनदेन पर हस्ताक्षर करने की भी अनुमति देता है6// ईथर भेजने और ब्लॉकचेन के भीतर स्थिति बदलने के लिए भुगतान करने की।7// इसके लिए, हमें खाता हस्ताक्षरकर्ता की आवश्यकता है...8const signer = provider.getSigner()Web3js example
1var web3 = new Web3("http://localhost:8545")2// या3var web3 = new Web3(new Web3.providers.HttpProvider("http://localhost:8545"))4
5// प्रदाता बदलें6web3.setProvider("ws://localhost:8546")7// या8web3.setProvider(new Web3.providers.WebsocketProvider("ws://localhost:8546"))9
10// node.js में IPC प्रदाता का उपयोग करना11var net = require("net")12var web3 = new Web3("/Users/myuser/Library/Ethereum/geth.ipc", net) // mac os पाथ13// या14var web3 = new Web3(15 new Web3.providers.IpcProvider("/Users/myuser/Library/Ethereum/geth.ipc", net)16) // mac os पाथ17// विंडोज़ पर पाथ है: "\\\\.\\pipe\\geth.ipc"18// लिनक्स पर पाथ है: "/users/myuser/.ethereum/geth.ipc"एक बार सेट अप करने के बाद आप ब्लॉकचेन को इसके लिए क्वेरी कर पाएंगे:
- ब्लॉक नंबर
- गैस का अनुमान
- स्मार्ट अनुबंध कार्यक्रम
- नेटवर्क Id
- और अधिक...
वॉलेट कार्यक्षमता
ये पुस्तकालय आपको वॉलेट बनाने, चाबियों का प्रबंधन करने और लेनदेन पर हस्ताक्षर करने की कार्यक्षमता प्रदान करते हैं।
यहाँ ईथर से एक उदाहरण है
1// एक स्मरक से एक वॉलेट इंस्टेंस बनाएं...2mnemonic =3 "announce room limb pattern dry unit scale effort smooth jazz weasel alcohol"4walletMnemonic = Wallet.fromPhrase(mnemonic)5
6// ...या एक निजी कुंजी से7walletPrivateKey = new Wallet(walletMnemonic.privateKey)8
9walletMnemonic.address === walletPrivateKey.address10// सही11
12// Signer API के अनुसार एक Promise के रूप में पता13walletMnemonic.getAddress()14// { Promise: '0x71CB05EE1b1F506fF321Da3dac38f25c0c9ce6E1' }15
16// एक वॉलेट पता समकालिक रूप से भी उपलब्ध है17walletMnemonic.address18// '0x71CB05EE1b1F506fF321Da3dac38f25c0c9ce6E1'19
20// आंतरिक क्रिप्टोग्राफ़िक घटक21walletMnemonic.privateKey22// '0x1da6847600b0ee25e9ad9a52abbd786dd2502fa4005dd5af9310b7cc7a3b25db'23walletMnemonic.publicKey24// '0x04b9e72dfd423bcf95b3801ac93f4392be5ff22143f9980eb78b3a860c4843bfd04829ae61cdba4b3b1978ac5fc64f5cc2f4350e35a108a9c9a92a81200a60cd64'25
26// वॉलेट स्मरक27walletMnemonic.mnemonic28// {29// locale: 'en',30// path: 'm/44\'/60\'/0\'/0/0',31// phrase: 'announce room limb pattern dry unit scale effort smooth jazz weasel alcohol'32// }33
34// ध्यान दें: एक निजी कुंजी के साथ बनाया गया वॉलेट नहीं होता35// एक स्मरक है (व्युत्पत्ति इसे रोकती है)36walletPrivateKey.mnemonic37// शून्य38
39// एक संदेश पर हस्ताक्षर करना40walletMnemonic.signMessage("Hello World")41// { Promise: '0x14280e5885a19f60e536de50097e96e3738c7acae4e9e62d67272d794b8127d31c03d9cd59781d4ee31fb4e1b893bd9b020ec67dfa65cfb51e2bdadbb1de26d91c' }42
43tx = {44 to: "0x8ba1f109551bD432803012645Ac136ddd64DBA72",45 value: utils.parseEther("1.0"),46}47
48// एक लेनदेन पर हस्ताक्षर करना49walletMnemonic.signTransaction(tx)50// { Promise: '0xf865808080948ba1f109551bd432803012645ac136ddd64dba72880de0b6b3a7640000801ca0918e294306d177ab7bd664f5e141436563854ebe0a3e523b9690b4922bbb52b8a01181612cec9c431c4257a79b8c9f0c980a2c49bb5a0e6ac52949163eeb565dfc' }51
52// कनेक्ट विधि का एक नया इंस्टेंस लौटाता है53// प्रदाता से जुड़ा वॉलेट54wallet = walletMnemonic.connect(provider)55
56// नेटवर्क से पूछताछ57wallet.getBalance()58// { Promise: { BigNumber: "42" } }59wallet.getTransactionCount()60// { Promise: 0 }61
62// ईथर भेजना63wallet.sendTransaction(tx)पूरे डॉक्स पढ़ें (opens in a new tab)
एक बार सेट अप करने के बाद आप निम्न में सक्षम होंगे:
- खाते बनाएँ
- लेन-देन भेजें
- लेन-देन पर हस्ताक्षर करें
- और अधिक...
स्मार्ट अनुबंध कार्यों के साथ इंटरैक्ट करें
जावास्क्रिप्ट क्लाइंट लाइब्रेरी आपके एप्लिकेशन को संकलित अनुबंध के एप्लिकेशन बाइनरी इंटरफ़ेस (एबीआई) को पढ़कर स्मार्ट अनुबंध फ़ंक्शन को कॉल करने की अनुमति देती है।
ABI अनिवार्य रूप से JSON प्रारूप में अनुबंध के कार्यों की व्याख्या करता है और आपको इसे सामान्य जावास्क्रिप्ट ऑब्जेक्ट की तरह उपयोग करने की अनुमति देता है।
तो निम्नलिखित सॉलिडिटी अनुबंध:
1contract Test {2 uint a;3 address d = 0x12345678901234567890123456789012;4
5 constructor(uint testInt) { a = testInt;}6
7 event Event(uint indexed b, bytes32 c);8
9 event Event2(uint indexed b, bytes32 c);10
11 function foo(uint b, bytes32 c) returns(address) {12 Event(b, c);13 return d;14 }15}निम्नलिखित JSON में परिणाम होगा:
1[{2 "type":"constructor",3 "payable":false,4 "stateMutability":"nonpayable"5 "inputs":[{"name":"testInt","type":"uint256"}],6 },{7 "type":"function",8 "name":"foo",9 "constant":false,10 "payable":false,11 "stateMutability":"nonpayable",12 "inputs":[{"name":"b","type":"uint256"}, {"name":"c","type":"bytes32"}],13 "outputs":[{"name":"","type":"address"}]14 },{15 "type":"event",16 "name":"Event",17 "inputs":[{"indexed":true,"name":"b","type":"uint256"}, {"indexed":false,"name":"c","type":"bytes32"}],18 "anonymous":false19 },{20 "type":"event",21 "name":"Event2",22 "inputs":[{"indexed":true,"name":"b","type":"uint256"},{"indexed":false,"name":"c","type":"bytes32"}],23 "anonymous":false24}]इसका मतलब है कि आप कर सकते हैं:
- स्मार्ट अनुबंध के लिए एक लेनदेन भेजें और इसकी विधि निष्पादित करें
- ईवीएम में निष्पादित होने पर गैस का अनुमान लगाने के लिए कॉल करें
- एक अनुबंध परिनियोजित करें
- और अधिक...
उपयोगिता फ़ंक्शंस
यूटिलिटी फ़ंक्शंस आपको आसान शॉर्टकट देते हैं जो एथेरियम के साथ निर्माण को थोड़ा आसान बनाते हैं।
ETH मान डिफ़ॉल्ट रूप से Wei में होते हैं. 1 ETH = 1,000,000,000,000,000,000 WEI - इसका मतलब है कि आप बहुत सारी संख्याओं के साथ काम कर रहे हैं! web3.utils.toWei आपके लिए ईथर को वेई में परिवर्तित करता है।
और ईथर में यह इस तरह दिखता है:
1// किसी खाते का बैलेंस प्राप्त करें (पते या ENS नाम से)2balance = await provider.getBalance("ethers.eth")3// { BigNumber: "2337132817842795605" }4
5// अक्सर आपको उपयोगकर्ता के लिए आउटपुट को प्रारूपित करने की आवश्यकता होगी6// जो वेई (wei) के बजाय ईथर में मान देखना पसंद करते हैं7ethers.utils.formatEther(balance)8// '2.337132817842795605'उपलब्ध लाइब्रेरीज़
वेब3.जेएस - एथेरियम जावास्क्रिप्ट एपीआई.
ईथर्स.जेएस - जावास्क्रिप्ट और टाइपस्क्रिप्ट में पूर्ण एथेरियम वॉलेट कार्यान्वयन और उपयोगिताएँ।
द ग्राफ - एथेरियम और आईपीएफएस डेटा को इंडेक्स करने और ग्राफक्यूएल का उपयोग करके इसे क्वेरी करने के लिए एक प्रोटोकॉल।
- द ग्राफ (opens in a new tab)
- ग्राफ एक्सप्लोरर (opens in a new tab)
- प्रलेखन (opens in a new tab)
- गिटहब (opens in a new tab)
- डिस्कॉर्ड (opens in a new tab)
अल्केमी SDK - उन्नत एपीआई के साथ ईथर्स.जेएस के चारों ओर रैपर।
viem - एथेरियम के लिए टाइपस्क्रिप्ट इंटरफ़ेस।
Drift - अंतर्निहित कैशिंग, हुक और परीक्षण मॉक्स के साथ टाइपस्क्रिप्ट मेटा-लाइब्रेरी।
आगे की रीडिंग
क्या आप किसी सामुदायिक संसाधन के बारे में जानते हैं जिसने आपकी मदद की हो? इस पृष्ठ को संपादित करें और इसे जोड़ें!
संबंधित विषय
संबंधित ट्यूटोरियल
- जावास्क्रिप्ट में एथेरियम ब्लॉकचेन का उपयोग करने के लिए Web3js सेट अप करें – अपने प्रोजेक्ट में web3.js को सेट अप करने के निर्देश।
- जावास्क्रिप्ट से स्मार्ट अनुबंध को कॉल करना – DAI टोकन का उपयोग करके, देखें कि जावास्क्रिप्ट का उपयोग करके अनुबंध फ़ंक्शन को कैसे कॉल किया जाए।
- web3 और अल्केमी का उपयोग करके लेनदेन भेजना – बैकएंड से लेनदेन भेजने के लिए चरण-दर-चरण पूर्वाभ्यास।