您的位置:首页 > 科技 > 能源 > react学习——20react编写github案列

react学习——20react编写github案列

2025/1/1 15:10:30 来源:https://blog.csdn.net/ChenJin_2/article/details/140044351  浏览:    关键词:react学习——20react编写github案列

1、List组件
index.js

import React, {Component} from "react";
//引入样式
import "./index.css";
export default class List extends Component {render() {const {users,isFirst,isLoding,err}=this.propsreturn(<div className="row">{isFirst?<h2>欢迎使用,输入关键字,随后点击搜素</h2>:isLoding?<h2>正在加载中...</h2>:err?<h2 style={{color:'red'}}>{err}</h2>:users.map((userObj)=>{return(<div key={userObj.id}  className="card"><a href={userObj.html_url} target="_blank" rel="noreferrer"><img alt={"reactjs"} src={userObj.avatar_url} style={{width: '100px'}}/></a><p className="card-text">{userObj.login}</p></div>)})}</div>);}
}

index.css

.album {min-height: 50rem; /* Can be removed; just added for demo purposes */padding-top: 3rem;padding-bottom: 3rem;background-color: #f7f7f7;
}.card {float: left;width: 33.333%;padding: .75rem;margin-bottom: 2rem;border: 1px solid #efefef;text-align: center;
}.card > img {margin-bottom: .75rem;border-radius: 100px;
}.card-text {font-size: 85%;
}

2、search组件

import React, {Component} from "react";
//引入axios
import axios from 'axios';
export default class Search extends Component {search = () =>{//获取用户的输入(连续解构赋值+重命名)const {keyword:{value:keyword}} = this;//发送请求前通知App组件更新状态this.props.updateAppState({isFirst:false,isLoding: true});//发送网络请求   https://api.github.com/search/users?q=xxxxxxaxios.get(`https://api.github.com/search/users?q=${keyword}`).then(res=>{const {items} = res.data;this.props.updateAppState({isLoding:false,users:items});console.log(items)},err=>{//请求失败通知App组件更新状态this.props.updateAppState({isLoding:false,err:err.message});})}render(){return(<section className="jumbotron"><h3 className="jumbotron-heading">Search Github Users</h3><div><input ref={c=>this.keyword=c} type="text" placeholder="enter the name you search"/>&nbsp;<button onClick={this.search}>Search</button></div></section>);}
}

3、App.js

//创建“外壳”组件APP
import React, {Component} from "react";
//引入Search组件
import Search from "./components/Search";
//引入List组件
import List from "./components/List";
//创建并暴露App组件
export default class App extends Component {state={users:[],isFirst:true,//是否第一次加载数据isLoding:false,//是否正在加载数据err:''//是否加载失败}updateAppState=(stateObj)=>{this.setState({...stateObj})}render() {return (<div className="container"><Search updateAppState={this.updateAppState}></Search><List {...this.state}></List></div>)}
}

5、index,js

//引入React核心库
import React from 'react';
//引入ReactDOM
import ReactDOM from 'react-dom/client';
import App from './App';
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(// <React.StrictMode>作用:在开发模式下,React 会在渲染组件时检查其代码,以发现一些常见错误。<React.StrictMode><App /></React.StrictMode>
);

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com