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 (
    
}/> }/>
); }; 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 (
      
); } return (
setsearch(e.target.value)} onkeydown={handlesearch} placeholder="search for a cryptocurrency" />
{filteredcrypto.map((val, id) => (
@@##@@

{val.name}

{val.symbol.touppercase()}

₹{val.current_price.tofixed(2)}

))}
); }; 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 (
      
); } return (

{cryptodetails.name}

{cryptodetails.symbol.touppercase()}

current price: ₹ {cryptodetails.market_data.current_price.inr.tofixed(2)}

@@##@@

description :

{cryptodetails.description.en}

market data

market cap: ₹ {cryptodetails.market_data.market_cap.inr.tolocalestring()}

total volume: ₹ {cryptodetails.market_data.total_volume.inr.tolocalestring()}

24h high: ₹{cryptodetails.market_data.high_24h.inr}

24h low: ₹{cryptodetails.market_data.low_24h.inr}

ECTouch移动商城系统
ECTouch移动商城系统

ECTouch是上海商创网络科技有限公司推出的一套基于 PHP 和 MySQL 数据库构建的开源且易于使用的移动商城网店系统!应用于各种服务器平台的高效、快速和易于管理的网店解决方案,采用稳定的MVC框架开发,完美对接ecshop系统与模板堂众多模板,为中小企业提供最佳的移动电商解决方案。ECTouch程序源代码完全无加密。安装时只需将已集成的文件夹放进指定位置,通过浏览器访问一键安装,无需对已有

下载

price change (24h): ₹ {cryptodetails.market_data.price_change_24h.tofixed(2)}

price change percentage (24h):{" "} {cryptodetails.market_data.price_change_percentage_24h.tofixed(2)}%

additional information

genesis date: {cryptodetails.genesis_date || "n/a"}

homepage:{" "} {cryptodetails.links.homepage[0]}

blockchain site:{" "} {cryptodetails.links.blockchain_site[0]}

); }; export default cryptodetails;

导航栏组件

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

import react from 'react'

const navbar = () => {
  return (
    

crypto finder

) } export default navbar

页脚组件

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

import React from 'react'

const Footer = () => {
  return (
    

Made with ❤️ by Abhishek Gurjar

) } export default Footer

现场演示

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

结论

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

制作人员

  • react 文档:react 文档
  • coingecko api:coingecko
  • axios 文档:axios 文档

作者

阿布舍克·古贾尔


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

{val.name}{cryptodetails.name}

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

265

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

758

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

761

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

605

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

560

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

397

2023.08.22

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 21.5万人学习

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

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