Integrating Web3.js with a mobile app allows you to build decentralized applications (dApps) that can interact with the Ethereum blockchain directly from mobile devices. In this guide, we will use React Native as our mobile framework to demonstrate how to integrate Web3.js.
Step 1: Set Up Your React Native Project
First, ensure you have Node.js and React Native CLI installed. Then, create a new React Native project by running:
npx react-native init MyDApp
Navigate into your project directory:
cd MyDApp
Step 2: Install Web3.js
Next, install the Web3.js library. In your project directory, run:
npm install web3
Step 3: Install React Native Dependencies
To interact with the Ethereum blockchain, you will also need to install the following dependencies:
npm install react-native-crypto react-native-randombytes
After installing the packages, link them to your project:
npx react-native link react-native-crypto
npx react-native link react-native-randombytes
Step 4: Set Up Web3.js in Your App
Open the App.js
file and set up Web3.js. Below is a sample code snippet:
import React, { useEffect, useState } from 'react';
import { View, Text, Button } from 'react-native';
import Web3 from 'web3';
const App = () => {
const [web3, setWeb3] = useState(null);
const [account, setAccount] = useState(null);
useEffect(() => {
const initWeb3 = async () => {
// Check if MetaMask is installed
if (window.ethereum) {
const web3Instance = new Web3(window.ethereum);
await window.ethereum.request({ method: 'eth_requestAccounts' });
const accounts = await web3Instance.eth.getAccounts();
setAccount(accounts[0]);
setWeb3(web3Instance);
} else {
alert('Please install MetaMask or another Ethereum wallet!');
}
};
initWeb3();
}, []);
return (
<View>
<Text>Welcome to My DApp!</Text>
{account ? <Text>Your account: {account}</Text> : <Text>Connecting...</Text>}
</View>
);
};
export default App;
Step 5: Interacting with Smart Contracts
To interact with a smart contract, you need the contract's ABI (Application Binary Interface) and its deployed address. You can obtain these from your smart contract deployment process.
const contractABI = [ /* ABI goes here */ ];
const contractAddress = '0xYourContractAddress';
const contract = new web3.eth.Contract(contractABI, contractAddress);
You can now call functions on your smart contract. For example, to call a function named getValue
:
const getValue = async () => {
const value = await contract.methods.getValue().call();
console.log(value);
};
Step 6: Sending Transactions
To send a transaction to your smart contract, use the following code:
const sendValue = async (newValue) => {
await contract.methods.setValue(newValue).send({ from: account });
};
Step 7: Testing on a Mobile Device
To run your React Native app on a physical device, you can use:
npx react-native run-android # for Android
npx react-native run-ios # for iOS
Make sure you have the necessary setup for Android or iOS development on your machine.
Conclusion
By following these steps, you can successfully integrate Web3.js with a mobile app built using React Native. This setup allows you to create powerful decentralized applications that can interact with the Ethereum blockchain directly from mobile devices.