首页 >web前端 >css教程 >使用 React 构建加密货币查找器应用程序

使用 React 构建加密货币查找器应用程序

DDD
DDD原创
2024-09-13 14:15:491226浏览

Building a Crypto Finder App with React

介绍

加密货币如今风靡一时,随着可用硬币的数量过多,有一个工具可以轻松搜索和查看它们的详细信息是至关重要的。 Crypto Finder 应用程序就是这样做的。该应用程序使用 React 构建,为用户搜索、过滤和查看加密货币详细信息提供无缝体验。

项目概况

Crypto Finder 应用程序包括:

  • 搜索界面:用户可以按名称搜索加密货币。
  • 加密货币列表:以卡片形式显示,显示基本信息。
  • 详细视图:单击加密货币卡可显示有关该货币的更多详细信息。

特征

  • 搜索功能:按名称过滤加密货币。
  • 动态路由:查看所选加密货币的详细信息。
  • 响应式设计:确保应用程序在不同的屏幕尺寸上看起来都不错。
  • 加载指示器:在获取数据时显示加载器。

使用的技术

  • React:用于构建用户界面。
  • Axios:用于发出 HTTP 请求。
  • React Router:用于路由和导航。
  • CoinGecko API:用于获取加密货币数据。

项目结构

以下是项目结构的快速概述:

  • 源代码/
    • 组件/
    • CryptoFinder.js
    • CryptoDetails.js
    • Navbar.js
    • 页脚.js
    • App.js
    • App.css

安装

要开始使用 Crypto Finder 应用程序,请按照以下步骤操作:

  1. 克隆存储库
   git clone https://github.com/abhishekgurjar-in/Crypto-Finder
   cd crypto-finder
  1. 安装依赖项
   npm install
  1. 启动开发服务器
   npm start
  1. 打开浏览器并导航到 http://localhost:3000 以查看正在运行的应用程序。

用法

  • 搜索加密货币:在搜索框中输入内容并单击“搜索”以过滤加密货币列表。
  • 查看详细信息:点击加密货币卡即可查看详细信息。

代码说明

应用程序组件

App.js 组件设置路由并包含导航栏和页脚组件。

import React from "react";
import CryptoFinder from "./components/CryptoFinder";
import "./App.css";
import Navbar from "./components/Navbar";
import Footer from "./components/Footer";
import {Route,Routes} from "react-router-dom"
import CryptoDetails from "./components/CryptoDetails";
const App = () => {
  return (
    <div>
      <Navbar />
      <Routes>
        <Route path="/" element={<CryptoFinder/>}/>
        <Route path="/details/:id" element={<CryptoDetails/>}/>
      </Routes>

      <Footer />
    </div>
  );
};

export default App;

CryptoFinder 组件

CryptoFinder.js 组件处理获取和显示加密货币列表。它包括一个用于过滤结果的搜索栏。

import React, { useEffect, useState } from "react";
import axios from "axios";
import { Link } from "react-router-dom";

const CryptoFinder = () => {
  const [search, setSearch] = useState("");
  const [crypto, setCrypto] = useState([]);
  const [filteredCrypto, setFilteredCrypto] = useState([]);

  useEffect(() => {
    axios
      .get(`https://api.coingecko.com/api/v3/coins/markets`, {
        params: {
          vs_currency: "inr",
          order: "market_cap_desc",
          per_page: 100,
          page: 1,
          sparkline: false,
        },
      })
      .then((res) => {
        setCrypto(res.data);
        setFilteredCrypto(res.data);
      });
  }, []);

  const handleSearch = () => {
    const filteredData = crypto.filter((data) => {
      return data.name.toLowerCase().includes(search.toLowerCase());
    });
    setFilteredCrypto(filteredData);
  };

  if (crypto.length === 0) {
    return (
      <div className="loader-box">
        <div className="loader"></div>
      </div>
    );
  }

  return (
    <div className="crypto-finder">
      <div className="input-box">
        <input
          type="text"
          value={search}
          onChange={(e) => setSearch(e.target.value)}
          onKeyDown={handleSearch}
          placeholder="Search for a cryptocurrency"
        />
        <button onClick={handleSearch}>Search</button>
      </div>
      <div className="cards">
        {filteredCrypto.map((val, id) => (
          <div className="card" key={id}>
            <img src={val.image} alt={val.name} />
            <h1>{val.name}</h1>
            <h4>{val.symbol.toUpperCase()}</h4>
            <h4>₹{val.current_price.toFixed(2)}</h4>
            <Link to={`/details/${val.id}`}>
              <button>View Details</button>
            </Link>
          </div>
        ))}
      </div>
    </div>
  );
};

export default CryptoFinder;

加密细节组件

CryptoDetails.js 组件获取并显示有关所选加密货币的详细信息。

import React, { useEffect, useState } from "react";
import axios from "axios";
import { useParams } from "react-router-dom";

const CryptoDetails = () => {
  const { id } = useParams();
  const [cryptoDetails, setCryptoDetails] = useState(null);

  useEffect(() => {
    axios
      .get(`https://api.coingecko.com/api/v3/coins/${id}`, {
        params: {
          localization: false,
        },
      })
      .then((res) => {
        setCryptoDetails(res.data);
      });
  }, [id]);

  if (!cryptoDetails) {
    return (
      <div className="loader-box">
        <div className="loader"></div>
      </div>
    );
  }

  return (
    <div className="crypto-details">
      <div className="basic-details-image-box">
        <div className="basic-details">
          <h1>{cryptoDetails.name}</h1>
          <h4>{cryptoDetails.symbol.toUpperCase()}</h4>
          <h4>
            Current Price: ₹
            {cryptoDetails.market_data.current_price.inr.toFixed(2)}
          </h4>
        </div>
        <div className="image-box">
          <img src={cryptoDetails.image.large} alt={cryptoDetails.name} />
        </div>
      </div>
      <div className="detail-desc">
      <h3>Description :</h3>
      <p >{cryptoDetails.description.en}</p>
      </div>


  <div className="market-and-additional">
  <div className="market-data">
        <h2>Market Data</h2>
        <p>
          <b>Market Cap: </b>₹
          {cryptoDetails.market_data.market_cap.inr.toLocaleString()}
        </p>
        <p>
          <b>Total Volume: </b>₹
          {cryptoDetails.market_data.total_volume.inr.toLocaleString()}
        </p>
        <p><b>24h High:</b> ₹{cryptoDetails.market_data.high_24h.inr}</p>
        <p><b>24h Low:</b> ₹{cryptoDetails.market_data.low_24h.inr}</p>
        <p>
         <b> Price Change (24h):</b> ₹
          {cryptoDetails.market_data.price_change_24h.toFixed(2)}
        </p>
        <p>
          <b>Price Change Percentage (24h):</b>{" "}
          {cryptoDetails.market_data.price_change_percentage_24h.toFixed(2)}%
        </p>
      </div>

      <div className="additional-info">
        <h2>Additional Information</h2>
        <p><b>Genesis Date:</b> {cryptoDetails.genesis_date || "N/A"}</p>
        <p>
          <b>Homepage:</b>{" "}
          <a
            href={cryptoDetails.links.homepage[0]}
            target="_blank"
            rel="noopener noreferrer"
          >
            {cryptoDetails.links.homepage[0]}
          </a>
        </p>
        <p>
         <b> Blockchain Site:</b>{" "}
          <a
            href={cryptoDetails.links.blockchain_site[0]}
            target="_blank"
            rel="noopener noreferrer"
          >
            {cryptoDetails.links.blockchain_site[0]}
          </a>
        </p>
      </div>
  </div>
    </div>
  );
};

export default CryptoDetails;

导航栏组件

Navbar.js 组件为应用程序提供标题。

import React from 'react'

const Navbar = () => {
  return (
    <div className="navbar">
    <h1>Crypto Finder</h1>
  </div>
  )
}

export default Navbar

页脚组件

Footer.js 组件为应用程序提供页脚。

import React from 'react'

const Footer = () => {
  return (
    <div className="footer">
    <p>Made with ❤️ by Abhishek Gurjar</p>
  </div>
  )
}

export default Footer

现场演示

您可以在此处查看 Crypto Finder 应用程序的实时演示。

结论

构建 Crypto Finder 应用程序是一次有趣且具有教育意义的体验。它演示了如何使用 React 来获取和显示数据、处理路由以及创建响应式且用户友好的界面。我希望这个项目对您有所帮助,并激励您使用 React 创建自己的应用程序!

制作人员

  • React 文档:React 文档
  • CoinGecko API:CoinGecko
  • Axios 文档:Axios 文档

作者

阿布舍克·古贾尔


您可以根据您的喜好或您可能已实现的其他功能随意调整或添加更多详细信息。

以上是使用 React 构建加密货币查找器应用程序的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn