0

0

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

DDD

DDD

发布时间:2024-09-13 14:41:31

|

1149人浏览过

|

来源于dev.to

转载

使用 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}>
            @@##@@
            <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">
          @@##@@
        </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><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/xiazai/code/10638" title="ECTouch移动商城系统"><img
                                                                                src="https://img.php.cn/upload/webcode/000/000/005/176309820356916.png" alt="ECTouch移动商城系统"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/xiazai/code/10638" title="ECTouch移动商城系统">ECTouch移动商城系统</a>
                                                                        <p>ECTouch是上海商创网络科技有限公司推出的一套基于 PHP 和 MySQL 数据库构建的开源且易于使用的移动商城网店系统!应用于各种服务器平台的高效、快速和易于管理的网店解决方案,采用稳定的MVC框架开发,完美对接ecshop系统与模板堂众多模板,为中小企业提供最佳的移动电商解决方案。ECTouch程序源代码完全无加密。安装时只需将已集成的文件夹放进指定位置,通过浏览器访问一键安装,无需对已有</p>
                                                                </div>
                                                                <a href="/xiazai/code/10638" title="ECTouch移动商城系统" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div>
        <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 文档

作者

阿布舍克·古贾尔


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

{val.name}{cryptodetails.name}

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6205

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

492

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

Js中concat和push的区别
Js中concat和push的区别

Js中concat和push的区别:1、concat用于将两个或多个数组合并成一个新数组,并返回这个新数组,而push用于向数组的末尾添加一个或多个元素,并返回修改后的数组的新长度;2、concat不会修改原始数组,是创建新的数组,而push会修改原数组,将新元素添加到原数组的末尾等等。本专题为大家提供concat和push相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.09.14

js截取字符串的方法介绍
js截取字符串的方法介绍

JavaScript字符串截取方法,包括substring、slice、substr、charAt和split方法。这些方法可以根据具体需求,灵活地截取字符串的不同部分。在实际开发中,根据具体情况选择合适的方法进行字符串截取,能够提高代码的效率和可读性 。

303

2023.09.21

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号