React训练营:基本元素的使用与状态管理
2022/3/26 23:25:04
本文主要是介绍React训练营:基本元素的使用与状态管理,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
前置条件
- node --version
- npm --version
- npx create-react-app react-project
入门样例
1.React中的状态
2.React中的语法糖
import React from 'react'; import ReactDOM from 'react-dom'; import './index.css'; const rootNode = document.getElementById('root'); function App() { //在函数中的状态管理 const [developer, setDeveloper] = React.useState({ name:"", language:"python", yearsExperience:0, isEmployed:false }); React.useEffect(()=>{ document.title = developer.name; },[developer.name]) function handleChangeLanguage(){ setDeveloper({ ...developer, language:"Javascript", yearsExperience:5 }); } function handleChangeYearsExperience(event){ setDeveloper({ ...developer, yearsExperience:event.target.value }) } function handleToggleEmployment(){ setDeveloper((prevState)=>({ ...developer, isEmployed:!developer.isEmployed })) } function handleChangeName(event){ setDeveloper({ ...developer, name:event.target.value }) } return ( <div> <div><button onClick={handleChangeLanguage}>Change Language</button></div> <div><button onClick={handleToggleEmployment}>Change isEmployed</button></div> <div>{developer.language}</div> <div> <input type="number" onChange={handleChangeYearsExperience}></input> <p>I have {developer.yearsExperience} years of experience</p> <p>Employment status:{developer.isEmployed? "Employed":"UnEmployed"}</p> <input type="text" placeholder="change name" onChange={handleChangeName}></input> </div> </div> ) } ReactDOM.render( <div> <App/> </div>, rootNode );
React中鼠标跟踪
- 使用状态
const [mousePostition,setMousePosition] = React.useState({ x:0,y:0});
- useEffect
React.useEffect(()=>{ document.addEventListener('mousemove',handleMouseMove); },[]);
- 鼠标监听事件
function handleMouseMove(event){ setMousePosition({x:event.pageX, y:event.pageY}); }
- 页面布局
<p> X :{mousePostition.x},Y:{mousePostition.y} </p>
- 离开页面时需要取消监听
React.useEffect(()=>{ document.addEventListener('mousemove',handleMouseMove); return ()=>{ document.removeEventListener('mousemove',handleMouseMove); } },[]);
Demo获取Github 中的个人信息
import React from 'react'; import ReactDOM from 'react-dom'; import './index.css'; const rootNode = document.getElementById('root'); const baseUrl = 'https://api.github.com/users/'; function App() { const [username,setUsername] = React.useState('rynerisraid') const [user,setUser] = React.useState(null); async function getUser(route){ const response = await fetch(`${baseUrl}${route}`); const data = await response.json(); setUser(data); } React.useEffect(()=>{ getUser(username); },[]); return ( <div> <input type="text" placeholder="Input username" onChange={event=>setUsername(event.target.value)} /> <button onClick={event=>getUser(username)}>Search</button> <button>Clear</button> {user? ( <div> <h2>User:{user.name}</h2> <p>{user.bio}</p> <img alt='avatar' src={user.avatar_url} style={{ height:50 }}></img> </div>) : (<p>Loading</p>)} </div> ) } ReactDOM.render(<App/>,rootNode);
这篇关于React训练营:基本元素的使用与状态管理的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-04React 19 来了!新的编译器简直太棒了!
- 2025-01-032025年Node.js与PHP大比拼:挑选最适合的后端技术进行现代web开发
- 2025-01-03?? 用 Gemini API、Next.js 和 TailwindCSS 快速搭建 AI 推文生成项目 ??
- 2024-12-31Vue CLI多环境配置学习入门
- 2024-12-31Vue CLI学习入门:一步一步搭建你的第一个Vue项目
- 2024-12-31Vue3公共组件学习入门:从零开始搭建实用组件库
- 2024-12-31Vue3公共组件学习入门教程
- 2024-12-31Vue3学习入门:新手必读教程
- 2024-12-31Vue3学习入门:初学者必备指南
- 2024-12-30Vue CLI多环境配置教程:轻松入门指南