React Js Currency Converter
React Js Currency Converter:A Reactjs Currency Converter is a web application built using the React.js library that allows users to convert currencies. It typically consists of input fields where users can specify the amount and select source and target currencies. React components handle the user interface and logic, fetching currency exchange rates from an API, and updating the converted amount dynamically as users make changes. This interactive and responsive tool provides real-time currency conversion, enhancing user experience and facilitating international financial transactions.




Thanks for your feedback!
Your contributions will help us to improve service.
How do I build a real-time currency converter in Reactjs?
The provided code is a React.js-based real-time currency converter. It allows users to input an amount in a source currency, select a target currency, and instantly see the converted amount. The app fetches exchange rate data from an external API (https://api.exchangerate-api.com) based on the selected source currency and updates the conversion when either the source currency, amount, or target currency changes. It utilizes React's useState and useEffect hooks to manage and update the currency conversion data. Users can interact with the app through input fields and select dropdowns for currency selection. The result is displayed below, showing the converted amount and currency names
React Js Currency Converter Example
<script type="text/babel">
const { useState, useEffect } = React;
function App() {
const [currencyData, setCurrencyData] = useState({
exchangeRates: {},
amount: 1,
fromCurrency: 'USD',
toCurrency: 'INR',
convertedAmount: null,
});
const currencyNames = {
AED: 'United Arab Emirates Dirham',
AFN: 'Afghan Afghani',
ALL: 'Albanian Lek',
AMD: 'Armenian Dram',
ANG: 'Netherlands Antillean Guilder',
AOA: 'Angolan Kwanza',
ARS: 'Argentine Peso',
AUD: 'Australian Dollar',
AWG: 'Aruban Florin',
AZN: 'Azerbaijani Manat',
BAM: 'Bosnia and Herzegovina Convertible Mark',
BBD: 'Barbadian Dollar',
BDT: 'Bangladeshi Taka',
BGN: 'Bulgarian Lev',
BHD: 'Bahraini Dinar',
BIF: 'Burundian Franc',
BMD: 'Bermudian Dollar',
BND: 'Brunei Dollar',
BOB: 'Bolivian Boliviano',
BRL: 'Brazilian Real',
BSD: 'Bahamian Dollar',
BTN: 'Bhutanese Ngultrum',
BWP: 'Botswana Pula',
BYN: 'Belarusian Ruble',
BZD: 'Belize Dollar',
CAD: 'Canadian Dollar',
CDF: 'Congolese Franc',
CHF: 'Swiss Franc',
CLP: 'Chilean Peso',
CNY: 'Chinese Yuan',
COP: 'Colombian Peso',
CRC: 'Costa Rican Colón',
CUP: 'Cuban Peso',
CVE: 'Cape Verdean Escudo',
CZK: 'Czech Koruna',
DJF: 'Djiboutian Franc',
DKK: 'Danish Krone',
DOP: 'Dominican Peso',
DZD: 'Algerian Dinar',
EGP: 'Egyptian Pound',
ERN: 'Eritrean Nakfa',
ETB: 'Ethiopian Birr',
EUR: 'Euro',
FJD: 'Fijian Dollar',
FKP: 'Falkland Islands Pound',
FOK: 'Faroese Króna',
GBP: 'British Pound Sterling',
GEL: 'Georgian Lari',
GGP: 'Guernsey Pound',
GHS: 'Ghanaian Cedi',
GIP: 'Gibraltar Pound',
GMD: 'Gambian Dalasi',
GNF: 'Guinean Franc',
GTQ: 'Guatemalan Quetzal',
GYD: 'Guyanese Dollar',
HKD: 'Hong Kong Dollar',
HNL: 'Honduran Lempira',
HRK: 'Croatian Kuna',
HTG: 'Haitian Gourde',
HUF: 'Hungarian Forint',
IDR: 'Indonesian Rupiah',
ILS: 'Israeli New Shekel',
IMP: 'Isle of Man Pound',
INR: 'Indian Rupee',
IQD: 'Iraqi Dinar',
IRR: 'Iranian Rial',
ISK: 'Icelandic Króna',
JEP: 'Jersey Pound',
JMD: 'Jamaican Dollar',
JOD: 'Jordanian Dinar',
JPY: 'Japanese Yen',
KES: 'Kenyan Shilling',
KGS: 'Kyrgyzstani Som',
KHR: 'Cambodian Riel',
KID: 'Kiribati Dollar',
KMF: 'Comorian Franc',
KRW: 'South Korean Won',
KWD: 'Kuwaiti Dinar',
KYD: 'Cayman Islands Dollar',
KZT: 'Kazakhstani Tenge',
LAK: 'Lao Kip',
LBP: 'Lebanese Pound',
LKR: 'Sri Lankan Rupee',
LRD: 'Liberian Dollar',
LSL: 'Lesotho Loti',
LYD: 'Libyan Dinar',
MAD: 'Moroccan Dirham',
MDL: 'Moldovan Leu',
MGA: 'Malagasy Ariary',
MKD: 'Macedonian Denar',
MMK: 'Burmese Kyat',
MNT: 'Mongolian Tögrög',
MOP: 'Macanese Pataca',
MRU: 'Mauritanian Ouguiya',
MUR: 'Mauritian Rupee',
MVR: 'Maldivian Rufiyaa',
MWK: 'Malawian Kwacha',
MXN: 'Mexican Peso',
MYR: 'Malaysian Ringgit',
MZN: 'Mozambican Metical',
NAD: 'Namibian Dollar',
NGN: 'Nigerian Naira',
NIO: 'Nicaraguan Córdoba',
NOK: 'Norwegian Krone',
NPR: 'Nepalese Rupee',
NZD: 'New Zealand Dollar',
OMR: 'Omani Rial',
PAB: 'Panamanian Balboa',
PEN: 'Peruvian Nuevo Sol',
PGK: 'Papua New Guinean Kina',
PHP: 'Philippine Peso',
PKR: 'Pakistani Rupee',
PLN: 'Polish Złoty',
PYG: 'Paraguayan Guarani',
QAR: 'Qatari Riyal',
RON: 'Romanian Leu',
RSD: 'Serbian Dinar',
RUB: 'Russian Ruble',
RWF: 'Rwandan Franc',
SAR: 'Saudi Riyal',
SBD: 'Solomon Islands Dollar',
SCR: 'Seychellois Rupee',
SDG: 'Sudanese Pound',
SEK: 'Swedish Krona',
SGD: 'Singapore Dollar',
SHP: 'Saint Helena Pound',
SLE: 'Sierra Leonean Leone',
SLL: 'Sierra Leonean Leone',
SOS: 'Somali Shilling',
SRD: 'Surinamese Dollar',
SSP: 'South Sudanese Pound',
STN: 'São Tomé and Príncipe Dobra',
SYP: 'Syrian Pound',
SZL: 'Swazi Lilangeni',
THB: 'Thai Baht',
TJS: 'Tajikistani Somoni',
TMT: 'Turkmenistani Manat',
TND: 'Tunisian Dinar',
TOP: 'Tongan Paanga',
TRY: 'Turkish Lira',
TTD: 'Trinidad and Tobago Dollar',
TVD: 'Tuvaluan Dollar',
TWD: 'New Taiwan Dollar',
TZS: 'Tanzanian Shilling',
UAH: 'Ukrainian Hryvnia',
UGX: 'Ugandan Shilling',
USD: 'United States Dollar',
UYU: 'Uruguayan Peso',
UZS: 'Uzbekistani Som',
VES: 'Venezuelan Bolívar',
VND: 'Vietnamese Đồng',
VUV: 'Vanuatu Vatu',
WST: 'Samoan Tala',
XAF: 'Central African CFA Franc',
XCD: 'Eastern Caribbean Dollar',
XDR: 'International Monetary Fund (IMF) Special Drawing Rights',
XOF: 'West African CFA Franc',
XPF: 'CFP Franc',
YER: 'Yemeni Rial',
ZAR: 'South African Rand',
ZMW: 'Zambian Kwacha',
ZWL: 'Zimbabwean Dollar',
};
useEffect(() => {
const { fromCurrency } = currencyData;
fetch(`https://api.exchangerate-api.com/v4/latest/${fromCurrency}`)
.then((response) => response.json())
.then((data) => {
setCurrencyData((prevData) => ({
...prevData,
exchangeRates: data.rates,
}));
})
.catch((error) => {
console.error('Error fetching data:', error);
});
}, [currencyData.fromCurrency]);
useEffect(() => {
const { amount, exchangeRates, toCurrency } = currencyData;
if (exchangeRates[toCurrency] !== undefined) {
setCurrencyData((prevData) => ({
...prevData,
convertedAmount: amount * exchangeRates[toCurrency],
}));
}
}, [currencyData.amount, currencyData.exchangeRates, currencyData.toCurrency]);
const handleInputChange = (e) => {
const { name, value } = e.target;
setCurrencyData((prevData) => ({
...prevData,
[name]: value,
}));
};
return (
<div className='container'>
<h1>React Js Real Time Currency Converter</h1>
<div>
<input
type="number"
name="amount"
value={currencyData.amount}
onChange={handleInputChange}
/>
<select
name="fromCurrency"
value={currencyData.fromCurrency}
onChange={handleInputChange}
>
{Object.keys(currencyData.exchangeRates).map((currency) => (
<option key={currency} value={currency}>
{`${currency} - ${currencyNames[currency]}`}
</option>
))}
</select>
<span>to</span>
<select
name="toCurrency"
value={currencyData.toCurrency}
onChange={handleInputChange}
>
{Object.keys(currencyData.exchangeRates).map((currency) => (
<option key={currency} value={currency}>
{`${currency} - ${currencyNames[currency]}`}
</option>
))}
</select>
</div>
<p>
{currencyData.amount} {currencyData.fromCurrency} (
{currencyNames[currencyData.fromCurrency]}) is approximately{' '}
{currencyData.convertedAmount} {currencyData.toCurrency} (
{currencyNames[currencyData.toCurrency]})
</p>
</div>
);
}
ReactDOM.render(<App />, document.getElementById('app'));
</script>