用 React 实现搜索 GitHub 用户功能

用 React 实现搜索 GitHub 用户功能

在本篇博客中,我们将介绍如何在 React 应用中搜索 GitHub 用户并显示他们的信息。

创建 React 应用

首先,我们使用 Create React App 创建一个新的 React 应用。Create React App 是一个快速搭建 React 项目的工具,它提供了一个现代化的开发环境,让我们能够专注于编写代码而不必担心配置问题。

npx create-react-app github-user-search

安装 axios

我们将使用 axios 来发起 HTTP 请求。Axios 是一个简单易用的 JavaScript HTTP 客户端,用于在浏览器和 Node.js 环境中进行 HTTP 请求。

npm install axios

编写搜索组件

接下来,我们创建一个名为 Search 的组件,用于输入搜索关键字并触发搜索操作。这个组件包含一个输入框和一个搜索按钮,用户可以在输入框中输入关键字,然后点击按钮或按下回车键进行搜索。

// Search.jsimport React, { Component } from 'react';export default class Search extends Component {state = {keyword: '',}onChange = (e) => {this.setState({ keyword: e.target.value });}onSearch = () => {const { keyword } = this.state;const { onSearch } = this.props;onSearch(keyword);}onKeyPress = (e) => {if (e.key === 'Enter') {this.onSearch();}}render() {return (<div className="input-group mb-3"><inputtype="text"className="form-control"placeholder="输入关键字"onChange={this.onChange}onKeyPress={this.onKeyPress}/><div className="input-group-append"><buttonclassName="btn btn-outline-secondary"type="button"onClick={this.onSearch}>搜索</button></div></div>)}
}

编写用户列表组件

接下来,我们创建一个名为 Users 的组件,用于显示搜索到的用户列表。这个组件接收一个用户列表作为 prop,并根据列表中的用户信息渲染用户卡片。

// Users.jsimport React, { Component } from 'react';
import User from './User';export default class Users extends Component {render() {const { users } = this.props;return (<div className="row row-cols-4 g-4">{users.map(user => <User key={user.node_id} user={user} />)}</div>)}
}

编写用户组件

然后,我们创建一个名为 User 的组件,用于显示单个用户的信息。这个组件接收一个用户对象作为 prop,并根据用户信息渲染用户卡片。

// User.jsimport React, { Component } from 'react';export default class User extends Component {render() {const { user } = this.props;return (<div className="border p-3 d-flex flex-column align-items-center" style={{ width: '240px' }}><imgsrc={user.avatar_url}alt={user.node_id}className="rounded-circle"style={{ width: '50px', height: '50px' }}/><h4 className="text-primary">{user.login}</h4></div>)}
}

编写应用主组件

最后,在 App 组件中集成上述组件,并实现搜索功能。这个组件是我们应用的入口点,它负责管理整个应用的状态和逻辑。

// App.jsimport React, { Component } from 'react';
import axios from 'axios';import Search from './Search';
import Users from './Users';export default class App extends Component {state = {users: [],}onSearch = async (keyword) => {const res = await axios.get(`/api/github/search/users?q=${keyword || 'h'}`);if (res && res.data) {this.setState({ users: res.data.items || [] });}}render() {const { users }= this.state;return (<div className="container" style={{ margin: '20px auto' }}><Search onSearch={this.onSearch} /><Users users={users} /></div>)}
}

部署并使用

现在,你可以部署你的应用,并开始搜索 GitHub 用户了!
在这里插入图片描述

参考

  • 用 React 实现搜索 GitHub 用户功能
  • 完整代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/493772.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Programming Abstractions in C阅读笔记:p303-p305

《Programming Abstractions in C》学习第74天&#xff0c;p303-p305总结&#xff0c;总计3页。 一、技术总结 1.时间复杂度分类(complexity classes) ClassNotationExampleconstantO(1)Returning the first element in an arraylogarithmicO(logN)Binary search in a sorte…

很基础!!!吴恩达deeplearning.ai:多分类问题

以下内容有任何不理解可以翻看我之前的博客哦&#xff1a;吴恩达deeplearning.ai 多分类问题指的是分类问题你可能有多于两个以上可能的输出标签&#xff08;而不只是0和1&#xff09;让我们通过例子具体看看是怎么样的。 文章目录 举例MNIST 例子&#xff08;手写数字识别问题…

深入理解Python中的JSON模块:基础大总结与实战代码解析【第102篇—JSON模块】

深入理解Python中的JSON模块&#xff1a;基础大总结与实战代码解析 在Python中&#xff0c;JSON&#xff08;JavaScript Object Notation&#xff09;模块是处理JSON数据的重要工具之一。JSON是一种轻量级的数据交换格式&#xff0c;广泛应用于Web开发、API通信等领域。本文将…

汽车电子笔记:BootLoader升级过程疑难问题解决方式(Bootloader响应10 02 + 刷死拯救机制)

目录 1、概述 2、如何在BootLoader响应10 02 2.1、实现流程图 2.2、实现方式&#xff08;代码思路&#xff09; 3、刷死拯救机制(100%能救活&#xff0c;适配各类控制器的方法) 3.1、强留Boot流程图 3.2、实现方式&#xff08;代码思路&#xff09; 1、概述 BootLoader作…

【C++进阶】仿函数 模板进阶

目录 前言 1. 仿函数 1.1 什么是仿函数 1.2 仿函数的应用 2. 模板 2.1 非类型模板参数 非类型模板参数的应用 2.2 模板特化 概念 函数模板的特化 类模板特化 全特化 偏特化 3. 模板分离编译问题 解决办法 4. 模板总结 总结 前言 我们已经基本学习完了C的一些基础特性&#x…

轻量级模型,重量级性能,TinyLlama、LiteLlama小模型火起来了,针对特定领域较小的语言模型是否与较大的模型同样有效?

轻量级模型&#xff0c;重量级性能&#xff0c;TinyLlama、LiteLlama小模型火起来了&#xff0c;针对特定领域较小的语言模型是否与较大的模型同样有效? 当大家都在研究大模型&#xff08;LLM&#xff09;参数规模达到百亿甚至千亿级别的同时&#xff0c;小巧且兼具高性能的小…

babylonjs入门

基于babylonjs封装的一些功能和插件 &#xff0c;希望有更多的小伙伴一起玩babylonjs&#xff1b; 欢迎加群&#xff1a;464146715 官方文档 中文文档 Babylonjs案例分享 ​ import React, { FC, useCallback, useEffect, useRef, useState } from react; import TemplateBB…

C++笔记之执行一个可执行文件时指定动态库所存放的文件夹lib的路径

C++笔记之执行一个可执行文件时指定动态库所存放的文件夹lib的路径 参考博文: 1.C++笔记之执行一个可执行文件时指定动态库所存放的文件夹lib的路径 2.Linux笔记之LD_LIBRARY_PATH详解 3.qt-C++笔记之使用QProcess去执行一个可执行文件时指定动态库所存放的文件夹lib的路径 c…

一款.NET下 WPF UI框架介绍

WPF开源的UI框架有很多,如HandyControl、MahApps.Metro、Xceed Extended WPF Toolkit™、Modern UI for WPF (MUI)、Layui-WPF、MaterialDesignInXamlToolkit、等等,今天小编带大家认识一款比较常用的kaiyuanUI---WPF UI,这款ui框架美观现代化,用起来也超级方便, 界面展示…

matlab生成模拟的通信信号

matlab中rand函数生成均匀随机分布的随机数&#xff0c;randn生成正态分布的随机数&#xff1b; matlab来模拟一个通信信号&#xff1b; 通信信号通过信道时&#xff0c;研究时认为它会被叠加上服从正态分布的噪声&#xff1b; 先生成随机信号模拟要传输的信号&#xff0c;s…

【深入理解设计模式】装饰者设计模式

装饰者设计模式 装饰者设计模式&#xff08;Decorator Design Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许向现有对象添加新功能而不改变其结构。这种模式通常用于需要动态地为对象添加功能或行为的情况&#xff0c;而且这些功能可以独立于对象本身来进行扩展…

Duplicate class kotlin.collections.jdk8.CollectionsJDK8Kt found in modules。Android studio纯java代码报错

我使用java代码 构建项目&#xff0c;初始代码运行就会报错。我使用的是Android Studio Giraffe&#xff08;Adroid-studio-2022.3.1.18-windows&#xff09;。我在网上找的解决办法是删除重复的类&#xff0c;但这操作起来真的太麻烦了。 这是全部报错代码&#xff1a; Dupli…