当前位置: 首页 > news >正文

react18基础速成

1、项目搭建

npx create-react-app my-react-app(项目名)

cd 项目名进入项目目录

终端输入 npm start 启动项目

浏览器查看

项目搭建成功

2、JSX

JavaScript语法和HTML语法写在一起就是JSX语法

jsx只能返回一个根元素,即最外层的div,也可以换成空标签<></>

3、数据渲染

3.1插值

插值可以使用的位置:1、标签内容2、标签属性

function App() {const divContent = "标签内容";const divTtitle = "标签标题";return <div title={divTtitle}>{divContent}</div>;
}export default App;

3.2条件渲染

function App() {const divTtitle = "标签标题";let divContent = null;const flag = false;if (flag) {divContent = <span>flag为true</span>;} else {divContent = <span>flag为false</span>;}return <div title={divTtitle}>{divContent}</div>;
}export default App;

3.3列表渲染

列表种的key唯一值是必要的,并且不推荐使用下标为key

function App() {const list = [{ id: 1, name: "小吴" },{ id: 2, name: "小李" },{ id: 3, name: "小花" },];const listContent = list.map((item) => <li key={item.id}>{item.name}</li>);return <ul>{listContent}</ul>;
}export default App;

我们给每个列表数据之后加一条虚线,并且还要符合jsx中只有一个根元素的原则,我们可以使用空标签,但是空标签不能写属性,并且遍历是存在多个根元素,这种情况类似一个documentFragment的情况,我们就可以使用Fragment组件来完成

import { Fragment } from "react";function App() {const list = [{ id: 1, name: "小吴" },{ id: 2, name: "小李" },{ id: 3, name: "小花" },];const listContent = list.map((item) => (<Fragment><li key={item.id}>{item.name}</li><li>-------------------------</li></Fragment>));return <ul>{listContent}</ul>;
}export default App;

4、事件处理

例如点击事件,react的事件大多数是驼峰命名的

function App() {function handleClick(e) {console.log("点击了按钮", e);}return <button onClick={handleClick}>按钮</button>;
}export default App;

5、useState状态处理

类似于vue的响应式状态机制

import { useState } from "react";function App() {const [content, setContent] = useState("标签的默认内容");function handleClick() {setContent("新内容");}return (<><div>{content}<button onClick={handleClick}>按钮</button></div></>);
}export default App;

5.1 对象形式的状态

import { useState } from "react";function App() {const [data, setData] = useState({title: "默认标题",content: "默认内容",});function handleClick() {setData({...data,content: "新标题",});}return (<><div><div title={data.title}>{data.content}</div><button onClick={handleClick}>按钮</button></div></>);
}export default App;

5.2数组形式的状态

import { useState } from "react";function App() {const [data, setData] = useState([{ id: 1, name: "小吴" },{ id: 2, name: "小李" },{ id: 3, name: "小花" },]);const listData = data.map((item) => <li key={item.id}>{item.name}</li>);let id = 3;function handleClick() {setData([...data, { id: ++id, name: "小明" }]);}return (<><div><ul>{listData}</ul><button onClick={handleClick}>按钮</button></div></>);
}export default App;

如果显示时需要过滤某个数据可以用filter

import { useState } from "react";function App() {const [data, setData] = useState([{ id: 1, name: "小吴" },{ id: 2, name: "小李" },{ id: 3, name: "小花" },]);const listData = data.map((item) => <li key={item.id}>{item.name}</li>);function handleClick() {setData(data.filter((item) => item.id !== 2));}return (<><div><ul>{listData}</ul><button onClick={handleClick}>按钮</button></div></>);
}export default App;

http://www.xdnf.cn/news/262423.html

相关文章:

  • AIGC时代——语义化AI驱动器:提示词的未来图景与技术深潜
  • Elasticsearch:RAG 和 grounding 的价值
  • 机器人--MCU
  • 【React】Hooks useReducer 详解,让状态管理更可预测、更高效
  • 提升办公效率的PDF转图片实用工具
  • Python面向对象编程实战:从类定义到高级特性的进阶之旅(2/10)
  • 参数包展开到初始化列表
  • WGDI-分析WGD及祖先核型演化的集成工具-文献精读126
  • 【中间件】brpc_基础_execution_queue
  • OpenharmonyOS+RK3568,【编译烧录】
  • Ubuntu 24.04 通过 update-alternatives 切换GCC版本
  • 什么是多租户系统
  • Maven 实现多模块项目依赖管理
  • WITH在MYSQL中的用法
  • 具身系列——PPO算法实现CartPole游戏(强化学习)
  • Oracle OCP认证考试考点详解083系列04
  • 单片机嵌入式按键库
  • Maven安装配置以及Idea中的配置教程
  • C# 操作符
  • 【LeetCode Hot100】栈篇
  • 计算机视觉与深度学习 | 视觉里程计算法综述(传统+深度)
  • 复刻低成本机械臂 SO-ARM100 组装篇(打螺丝喽)
  • firewall docker 冲突问题解决(亲测有效)
  • Windows下编译WebRTC源码
  • [更新完毕]2025东三省C题深圳杯C题数学建模挑战赛数模思路代码文章教学: 分布式能源接入配电网的风险分析
  • AtCoder Beginner Contest 404(ABCDE)
  • 什么是运算符重载
  • word怎么删除空白页?word最后一页删不掉怎么办
  • 基于开源AI大模型与AI智能名片S2B2C商城小程序的线上活动执行优化研究
  • SQL中的Subquery CTE Temporary Table 区别