React 前端框架实战教程

📝个人主页🌹:一ge科研小菜鸡-CSDN博客
🌹🌹期待您的关注 🌹🌹

引言

React 是由 Facebook 开发的前端 JavaScript 库,旨在构建高效、灵活的用户界面,尤其适用于单页应用(SPA)。它采用组件化开发模式,并使用虚拟 DOM 技术,提高应用的性能和可维护性。React 目前已成为最流行的前端框架之一,被广泛应用于各类 Web 应用开发中。

本教程将详细介绍 React 的核心概念、组件开发、状态管理、路由配置、API 调用以及最佳实践,并提供代码示例,帮助开发者快速上手 React。


1. React 核心概念

React 的核心概念主要包括:

概念说明示例
组件(Component)UI 的最小单元,分为类组件和函数组件function MyComponent() {...}
JSXJavaScript 语法扩展,用于描述 UI 结构<h1>Hello, React!</h1>
状态(State)组件内部数据,驱动 UI 更新useState
属性(Props)组件间传递数据的方式<MyComponent name="React"/>
虚拟 DOM提升性能的高效 DOM 变更处理React.createElement()
生命周期组件的创建、更新和销毁过程componentDidMount

2. React 开发环境搭建

2.1 安装 Node.js

首先,安装最新的 Node.js 版本,可前往 Node.js 官方网站 下载。

2.2 创建 React 项目

使用 Create React App(CRA)快速创建项目:

npx create-react-app my-react-app
cd my-react-app
npm start

项目结构:

my-react-app/
│-- node_modules/
│-- public/
│-- src/
│   ├── App.js
│   ├── index.js
│   ├── components/
│   ├── styles/
│   ├── services/
│-- package.json
│-- README.md

2.3 运行项目

执行以下命令启动 React 开发服务器:

npm start

3. React 组件开发

3.1 函数组件与类组件

函数组件示例(推荐)
import React from 'react';function Welcome(props) {return <h1>欢迎, {props.name}!</h1>;
}export default Welcome;
类组件示例
import React, { Component } from 'react';class Welcome extends Component {render() {return <h1>欢迎, {this.props.name}!</h1>;}
}export default Welcome;

3.2 组件的状态管理

使用 useState 管理组件的状态:

import React, { useState } from 'react';function Counter() {const [count, setCount] = useState(0);return (<div><p>当前计数: {count}</p><button onClick={() => setCount(count + 1)}>增加</button></div>);
}export default Counter;

4. 事件处理与数据绑定

在 React 中,事件处理类似于 DOM 操作,但需使用 CamelCase 方式定义事件。

4.1 事件绑定示例

function ButtonClick() {function handleClick() {alert('按钮被点击了!');}return <button onClick={handleClick}>点击我</button>;
}export default ButtonClick;

5. React 路由(React Router)

React Router 是一个用于管理 SPA 应用页面导航的库。

5.1 安装 React Router

npm install react-router-dom

5.2 配置路由

import React from 'react';
import { BrowserRouter as Router, Routes, Route, Link } from 'react-router-dom';function Home() {return <h2>首页</h2>;
}function About() {return <h2>关于我们</h2>;
}function App() {return (<Router><nav><Link to="/">首页</Link> | <Link to="/about">关于</Link></nav><Routes><Route path="/" element={<Home />} /><Route path="/about" element={<About />} /></Routes></Router>);
}export default App;

6. 状态管理(Redux)

React 应用的状态管理通常可以使用 Redux 来实现。

6.1 安装 Redux

npm install redux react-redux

6.2 创建 Redux Store

import { createStore } from 'redux';const initialState = { count: 0 };function counterReducer(state = initialState, action) {switch (action.type) {case 'INCREMENT':return { count: state.count + 1 };default:return state;}
}const store = createStore(counterReducer);
export default store;

6.3 连接 React 组件

import React from 'react';
import { useSelector, useDispatch } from 'react-redux';function Counter() {const count = useSelector(state => state.count);const dispatch = useDispatch();return (<div><p>计数: {count}</p><button onClick={() => dispatch({ type: 'INCREMENT' })}>增加</button></div>);
}export default Counter;

7. React API 请求(Axios)

React 中常用 Axios 进行 API 请求。

7.1 安装 Axios

npm install axios

7.2 API 请求示例

import React, { useEffect, useState } from 'react';
import axios from 'axios';function DataFetch() {const [data, setData] = useState([]);useEffect(() => {axios.get('https://jsonplaceholder.typicode.com/posts').then(response => setData(response.data)).catch(error => console.error('数据获取失败:', error));}, []);return (<ul>{data.map(post => (<li key={post.id}>{post.title}</li>))}</ul>);
}export default DataFetch;

8. 部署 React 应用

使用以下命令打包 React 应用以进行生产部署:

npm run build

打包后的文件将存储在 build/ 目录,可直接部署至服务器或托管于 GitHub Pages 或 Netlify。


9. 结论与展望

React 提供了现代化的前端开发体验,凭借其强大的组件化、状态管理及生态系统,已成为前端开发的首选框架。

下一步学习建议:

  1. 深入学习 Hooks(useEffectuseContext
  2. 探索高级状态管理工具,如 Recoil、Zustand
  3. 了解 React 服务端渲染(Next.js)

希望本教程能够帮助您快速掌握 React 开发技能!

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

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

相关文章

【Linux线程总结】VMA ELF 地址转换 同步和互斥 条件变量 PC模型 循环队列 POSIX信号量 线程池

文章目录 VMAELF地址转换线程相关函数同步和互斥引入条件变量总结条件变量PC模型循环队列POSIX信号量接口posix信号量和systemV信号量主要异同适用场景总结 基于循环队列的PCModel 锁--条件变量--信号量 的产生由来线程相关问题线程池回顾进程池 VMA ELF Executable and Linka…

基于ESP32的桌面小屏幕实战[6]:环境搭建和软件基础

摘要 本文分为两部分&#xff1a;Linux开发环境搭建和软件基础。Linux开发环境搭建介绍了Ubuntu虚拟机安装及SSH、Samba配置&#xff0c;可以实现用VSCode操作虚拟机。为了后续工作&#xff0c;搭建了乐鑫ESP32 SDK环境。软件基础介绍了Linux开发常用的软件基础&#xff0c;包…

FreeRtos的使用教程

定义&#xff1a; RTOS实时操作系统, (Real Time Operating System), 指的是当外界事件发生时, 能够有够快的响应速度,调度一切可利用的资源, 控制实时任务协调一致的运行。 特点&#xff1a; 支持多任务管理&#xff0c; 处理多个事件&#xff0c; 实现更复杂的逻辑。 与计算…

【精选】基于数据挖掘的招聘信息分析与市场需求预测系统 职位分析、求职者趋势分析 职位匹配、人才趋势、市场需求分析数据挖掘技术 职位需求分析、人才市场趋势预测

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

Go中的三种锁

Go 中的锁 Go 语言提供了多种锁机制&#xff0c;用于在并发编程中保护共享资源。常见的锁包括 互斥锁、读写锁 和 sync.Map 的安全锁。 1. 互斥锁&#xff08;Mutex&#xff09; 原理 互斥锁&#xff08;sync.Mutex&#xff09;是一种最简单的锁机制&#xff0c;用于保护共…

2025美赛数学建模C题:奥运金牌榜,完整论文代码模型目前已经更新

2025美赛数学建模C题&#xff1a;奥运金牌榜&#xff0c;完整论文代码模型目前已经更新&#xff0c;获取见文末名片

【数据结构】深入解析:构建父子节点树形数据结构并返回前端

树形数据结构列表 一、前言二、测试数据生成三、树形代码3.1、获取根节点3.2、遍历根节点&#xff0c;递归获取所有子节点3.3、排序3.4、完整代码 一、前言 返回前端VO对象中&#xff0c;有列情况列表展示需要带树形结构&#xff0c;例如基于RBAC权限模型中的菜单返回&#xf…

Docker快速部署高效照片管理系统LibrePhotos搭建私有云相册

文章目录 前言1.关于LibrePhotos2.本地部署LibrePhotos3.LibrePhotos简单使用4. 安装内网穿透5.配置LibrePhotos公网地址6. 配置固定公网地址 前言 想象一下这样的场景&#xff1a;你有一大堆珍贵的回忆照片&#xff0c;但又不想使用各种网盘来管理。怎么办&#xff1f;别担心…

【开源免费】基于Vue和SpringBoot的医院资源管理系统(附论文)

本文项目编号 T 161 &#xff0c;文末自助获取源码 \color{red}{T161&#xff0c;文末自助获取源码} T161&#xff0c;文末自助获取源码 目录 一、系统介绍二、数据库设计三、配套教程3.1 启动教程3.2 讲解视频3.3 二次开发教程 四、功能截图五、文案资料5.1 选题背景5.2 国内…

被占用的电脑文件推沟里

在使用电脑的过程中&#xff0c;你是否遇到过这种情况&#xff1a;想删除、移动或重命名一个文件&#xff0c;结果系统无情地告诉你——“文件被占用&#xff0c;无法操作&#xff01;”这时候&#xff0c;IObit Unlocker 就该闪亮登场了&#xff01;这款免费的文件解锁工具&am…

Coze插件开发之基于已有服务创建并上架到扣子商店

Coze插件开发之基于已有服务创建并上架到扣子商店 在应用开发中&#xff0c;需要调用各种插件&#xff0c;以快速进行开发。但有时需要调用的插件在扣子商店里没有&#xff0c;那怎么办呢&#xff1f; 今天就来带大家快速基于已有服务创建一个新的插件 简单来讲&#xff0c;就是…

微信小程序-点餐(美食屋)02开发实践

目录 概要 整体架构流程 &#xff08;一&#xff09;用户注册与登录 &#xff08;二&#xff09;菜品浏览与点餐 &#xff08;三&#xff09;订单管理 &#xff08;四&#xff09;后台管理 部分代码展示 1.index.wxml 2.list.wxml 3.checkout.wxml 4.detail.wxml 小结优点 概要…

[Dialog屏幕开发] 屏幕绘制(下拉菜单)

阅读该篇文章之前&#xff0c;可先阅读下述资料 [Dialog屏幕开发] Table Control 列数据操作https://blog.csdn.net/Hudas/article/details/145343731?spm1001.2014.3001.5501上篇文章我们的屏幕已实现了如下功能 我们已经设置了按钮对Table Control 列的数据进行了操作 接下…

类与对象(下)

再谈构造函数 构造函数体赋值 在创建对象时&#xff0c;编译器通过调用构造函数&#xff0c;给对象中各个成员变量一个合适的初始值 class Date { public: Date(int year, int month, int day){_year year;_month month;_day day;} private: int _year; int _month; int _d…

【机器学习】深入探索SVM:支持向量机的原理与应用

目录 &#x1f354; SVM引入 1.1什么是SVM? 1.2支持向量机分类 1.3 线性可分、线性和非线性的区分 &#x1f354; 小结 学习目标 知道SVM的概念 &#x1f354; SVM引入 1.1什么是SVM? 看一个故事&#xff0c;故事是这样子的&#xff1a; 在很久以前的情人节&#xf…

Dev-C++分辨率低-解决办法

目录 【工具】Dev-C分辨率低-解决办法问题背景完整操作指南第一步&#xff1a;打开属性设置 【工具】Dev-C分辨率低-解决办法 问题背景 Dev-C因版本老旧&#xff08;长期未更新&#xff09;&#xff0c;在高分辨率显示器上存在界面模糊问题。通过修改Windows兼容性设置可优化…

[VSCode] vscode下载安装及安装中文插件详解(附下载链接)

VSCode 是一款由微软开发且跨平台的免费源代码编辑器&#xff1b;该软件支持语法高亮、代码自动补全、代码重构、查看定义功能&#xff0c;并且内置了命令行工具和Git版本控制系统。 下载链接&#xff1a;https://pan.quark.cn/s/3a90aef4b645 提取码&#xff1a;NFy5 通过上面…

javascript-es6 (一)

作用域&#xff08;scope&#xff09; 规定了变量能够被访问的“范围”&#xff0c;离开了这个“范围”变量便不能被访问 局部作用域 函数作用域&#xff1a; 在函数内部声明的变量只能在函数内部被访问&#xff0c;外部无法直接访问 function getSum(){ //函数内部是函数作用…

c语言中的数组(上)

数组的概念 数组是⼀组相同类型元素的集合&#xff1b; 数组中存放的是1个或者多个数据&#xff0c;但是数组元素个数不能为0。 数组中存放的多个数据&#xff0c;类型是相同的。 数组分为⼀维数组和多维数组&#xff0c;多维数组⼀般⽐较多⻅的是⼆维数组。 数组创建 在C语言…

C#,入门教程(05)——Visual Studio 2022源程序(源代码)自动排版的功能动画图示

上一篇&#xff1a; C#&#xff0c;入门教程(04)——Visual Studio 2022 数据编程实例&#xff1a;随机数与组合https://blog.csdn.net/beijinghorn/article/details/123533838https://blog.csdn.net/beijinghorn/article/details/123533838 新来的徒弟们交上来的C#代码&#…