前端学习--React(1)
一、React简介
React由Meta公司研发,是一个用于 构建Web和原生交互界面的库
优势:组件化开发、不错的性能、丰富生态(所有框架中最好)、跨平台(web、ios、安卓)
开发环境搭建
打开相应文件夹 新建终端并输入
npx create-react-app react1
就可以得到一个名为react1 的项目
运行一下↓

在package.json中,这是两个核心依赖包
"react": "^18.2.0",
"react-dom": "^18.2.0",
下面是可以执行的命令,开发阶段执行start,开发完毕打包执行build
"scripts": {"start": "react-scripts start","build": "react-scripts build","test": "react-scripts test","eject": "react-scripts eject"},
所有的开发工作在src中执行,最开始只保留App.js和index.js即可
然后精简一下App.js和index.js
//index.js//项目入口
//导入必要的核心包
import React from 'react';
import ReactDOM from 'react-dom/client';
//导入项目根组件
import App from './App';
//把App根组件渲染到index.html中id为root的dom节点上
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />
);
//App.js
//项目根组件
function App() {return (<div className="App">this is react</div>);
}export default App;
二、JSX基础
JSX基础和概念
JSX是JavaScript和XML(HTML)的缩写,表示在JS代码中编写HTML模版结构,它是React中编写 UI模版的方式

既具有HTML声明式写法,又有JS的可编程能力
JSX在原生JS中无法被识别,那如何渲染到浏览器中?
JSX本质
是js语法扩展,需要解析工具(babel)才能在浏览器中运行
Babel · Babel (babeljs.io)

JSX场景
jsx可以通过{}识别js表达式,有以下四种情况:
1. 使用引号传递字符串
2. 使用JavaScript变量
3. 函数调用和方法调用
4. 使用JavaScript对象
function printName(){return 'Rose'
}function App() {const count = 1000return (<div className="App">{/*1 使用引号传递字符串 */}{'this is react project'}{/* 2 识别js变量 */}{count}{/* 3 函数调用 */}{printName()}{/* 4 方法调用 */}{new Date().getDate()}{/* 5 使用js对象 */}{/* 外层花括号是识别表达式的语法,内层是对象结构 */}<div style={{color : 'red'}}>this is red color</div></div>);
}export default App;

JSX列表渲染
核心方法是map,循环哪个结构就在map里return哪个结构,不要忘记每个循环元素都要有唯一标识key
const list = [{name:'Alice',id:1001},{name:'Bob',id:1002},{name:'Candy',id:1003}
]function App() {return (<div className="App">this is a list<ul>{list.map(item => <li key={item.id}>{item.name}</li>)}</ul></div>);
}

JSX条件渲染
基础情况
可以通过逻辑与&&(控制一个元素)和三元表达式:?(两个元素)实现基础的条件渲染
const showSpan = true
function App() {return (<div className="App">{/* 逻辑& */}{showSpan && <span>hello</span>}{/* 三元表达式 */}{showSpan ? <span> showSpan为true</span> : <span>showSpan为false</span>}</div>);
}
复杂情况
用if-else
const type = 1
function getType(){if(type === 1){return <div>我是1</div>}else if(type === 2){return <div>我是2</div>}else{return <div>我是3</div>}
}
function App() {return (<div className="App">{/* 逻辑& */}{getType()}</div>);
}
三、事件绑定
on + 事件名称 = { 事件处理程序 },整体上遵循驼峰命名
function App() {let count = 0const handleClick = () => {count ++console.log('button被点击了'+count)}return (<div className="App"><button onClick={handleClick}> click </button></div>);
}
如果是自定义参数,要写成箭头函数
<button onClick={() => handleClick(1)}> click </button>
事件对象e和自定义参数都需要
<button onClick={(e) => handleClick(e, 1)}> click </button>
四、React组件
在不同的前端框架,组件是通用概念,组件之间可以嵌套也可以复用
const Button = () => {return <button>Click</button>
}
function App() {return (<div className="App"><Button></Button><Button/></div>);
}
五、useState
useState 是一个 React Hook(函数),它允许我们向组件添加一个状态变量, 从而控制影响组件的渲染结果
即数据驱动视图
下面是一个典型自增按钮
import { useState } from "react";
function App() {//count是状态变量, setCount是修改变量的方法 每次修改count必须调用setCountconst [count, setCount] = useState(0)const handleClick = () => {setCount(count + 1)}return (<div className="App"><button onClick={handleClick}>{count}</button></div>);
}
react中的状态只读,每次应该通过修改状态的函数来替换,直接修改不能引发视图更新
修改对象属性
import { useState } from "react";
function App() {const [student, setStu] = useState({name:'Jack',age:20})const handleClick2 = () => {setStu({...student, //这一行保留,那么只修改name一个属性,反之原有属性都会被覆盖掉name:'XiaoMing'})console.log(student)}return (<div className="App"><button onClick={handleClick2}>{student.name}</button></div>);
}
六、组件样式处理
行内样式
const style = {color:'pink',fontWeight:'700',fontSize:'20px'
}
function App() {return (<div className="App"><span style={style}> 11 </span></div>);
}
class类名控制
//index.css
.fc-lightblue{color: lightblue;
}//index.js
import './index.css'
function App() {return (<div className="App"><span className='fc-lightblue'> 11 </span></div>);
}
案例应用
lodash数组排序
Lodash Documentation
npm i lodash
_.orderBy(collection, [iteratees=[_.identity]], [orders])
//参数分别是 要排序的数组 排序参照属性 排序方法(asc/desc)
classnames动态控制类名
npm i classnames
import classNames from 'classnames'<span className={classNames('class1', {class2: type === item.type})}>{item.text}
</span>
相关文章:
前端学习--React(1)
一、React简介 React由Meta公司研发,是一个用于 构建Web和原生交互界面的库 优势:组件化开发、不错的性能、丰富生态(所有框架中最好)、跨平台(web、ios、安卓) 开发环境搭建 打开相应文件夹 新建终端并…...
HarmonyOS从基础到实战-高性能华为在线答题元服务
最近看到美团、新浪、去哪儿多家互联网企业启动鸿蒙原生应用开发,这个HarmonyOS NEXT越来越引人关注。奈何当前不面向个人开发者开放,但是我们可以尝试下鸿蒙新的应用形态——元服务的开发。 元服务是基于HarmonyOS提供的一种面向未来的服务提供方式&…...
OpenCV快速入门:窗口交互
文章目录 前言一、鼠标操作1.1 鼠标操作简介1.2 鼠标事件类型(event类型)1.3 鼠标事件标志(flags)1.4 代码示例1.4.1 获取鼠标坐标位置1.4.2 监听鼠标滚轮事件1.4.3 在图像中显示鼠标坐标 二、键盘操作2.1 代码示例2.2 waitKey的等…...
数据智能引擎:企业模糊搜索API精准获取企业列表信息
引言 随着信息时代的迅速发展,数据变得愈加庞大和复杂。在这个大数据的时代,企业面临着海量信息的管理和利用挑战。为了更有效地获取并利用数据,企业信息模糊搜索API成为了企业数据智能引擎的一部分,为企业提供了精准的企业列表检…...
汇编-间接寻址(处理数组)
直接寻址很少用于数组处理,因为用常数偏移量来寻址多个数组元素时,直接寻址并不实用。取而代之的是使用寄存器作为指针(称为间接寻址(indirect addressing) ) 并控制该寄存器的值。如果一个操作数使用的是间接寻址, 就称之为间接操作数(indie…...
lombok 的使用讲解
目录 前言1. 基本知识2. 代码应用 前言 在项目中经常会看到lombok的应用,此文作为科普帖,详细介绍lombok 1. 基本知识 简介: Project Lombok是一款用于Java开发的工具,旨在通过自动生成样板代码来简化Java代码的编写。 它通过注…...
echarts的使用
1. 普通版 其实主要就是option1,option1就是画的图 echats不能响应刷新,要想实时刷新监听刷新的值重新调用一下方法即可 html <div class"echart" style"width: 100%;height: calc(100% - 130px)" ref"main1">&l…...
js进阶笔记之构造函数
目录 一、构造函数 1、 创建对象 2、new执行过程 3、带参数构造函数 4、实例成员与静态成员 二、内置构造函数 1、Object静态方法 2、包装类型 3、Array 1、map方法 2、find方法 3、findIndex( ) 4、some与every 5、reverse() 6、reduce方法 7、forEach() …...
Codesys数据类型(2.7):扩展数据类型之 别名 详解
Codesys代码代写,程序开发,软件定制,bug修改,问题咨询: T宝搜索店铺【林磊教育】 定义及声明 别名的目的是声明出 基本数据类型,结构体,枚举、共用体(UNION)、功能块、指针备用名字,…...
白盒子测试总结
白盒子测试,也称为结构测试、透明盒测试、逻辑驱动测试或基于代码的测试,是一种测试用例的设计方法。白盒测试需要全面了解被测试程序的内部逻辑结构,并对所有逻辑路径进行测试。其基本方法包括: 语句覆盖:设计若干个…...
字符数组基础知识
字符数组是存放字符数据的数组,其中每一个元素存放的值都是单个字符。 字符数组:由字符类型的元素组成,其定义与初始化方式,以及对数组元素的引用都与整数数组类似,代码示例 char c[5]{h,e,l,l,,o}; 注意࿱…...
Oracle EBS 重新打开库存会期间
由库存某些账务用户操作错误,如:汇率错误、单位转换错误、BOM单据用量错误,需要反向操作纠正少量而有影响成本比较大的数据。但是,库存会计期已经关闭,需要重新打开库存会计期。根据官方文整理一份重新打开库存期间的脚本: 测试Oracle EBS版本: RDBMS : 12.1.0.2.0 Orac…...
java项目之社区互助平台(ssm+vue)
项目简介 社区互助平台实现了以下功能: 1、一般用户的功能及权限 所谓一般用户就是指还没有注册的过客,他们可以浏览主页面上的信息。但如果有中意的社区互助信息时,要登录注册,只有注册成功才有的权限。2、管理员的功能及权限 用户信息的添…...
unity C#设置文件为不可见
unity C#设置文件为不可见 /// ///设置文件为隐藏// /// using UnityEngine; using System.IO;public class SetFolderInvisible : MonoBehaviour {private void Start(){string folderPath "Qi/Video";// 将文件夹属性设置为隐藏和系统SetFolderAttributes(folder…...
DITTEL控制器维修SENSITRON6-2AE
DITTEL工控产品维修包括:德国DITTEL平衡测试仪维修,DITTEL模块,过程监控模块,DITTEL控制器,平衡头,机电平衡头,显示器,平衡系统等产品。 DITTEL过程控制模块维修 DM6000是一个过程控制模块&…...
django restful framework序列化与反序列化
在前后端分离开发中,对于RESTfulAPI设置,一般需要将查询/更新数据以JSON方式进行返回。 序列化 Model.py from django.db import models class User(models.Model):username models.CharField(verbose_name用户名,max_length10)age models.IntegerF…...
Flutter:多线程Isolate的简单使用
在flutter中如果要使用线程,需要借助Isolate来实现。 简介 在Flutter中,Isolate是一种轻量级的线程解决方案,用于在应用程序中执行并发任务。Isolate可以被认为是独立于主线程的工作单元,它们可以在后台执行任务而不会阻塞应用程…...
SAP的一些当说不说的常识
ABAP中的WDA与FRMbopf restful和odata postman软件 SAP中MM模块相关 SAP 物料 移动类型 https://www.cnblogs.com/rainysblog/p/4133259.html T移动类型文本含义一般用途T-code101GR 收货直接收货工单入库,购买成品入库MIGO/CO11N102用于PO冲销的收货冲销直接…...
Java运行时数据区和常用指令
Java运行时数据区是Java虚拟机规范中定义的一块区域,用于存储Java程序在运行过程中需要使用到的数据。这些数据包括: 1. 堆区:用于存储对象实例,是Java内存中最大的一块区域。2. 方法区:用于存储已被虚拟机加载的类信…...
hdfsClient_java对hdfs进行上传、下载、删除、移动、打印文件信息尚硅谷大海哥
Java可以通过Hadoop提供的HDFS Java API来控制HDFS。通过HDFS Java API,可以实现对HDFS的文件操作,包括文件的创建、读取、写入、删除等操作。 具体来说,Java可以通过HDFS Java API来创建一个HDFS文件系统对象,然后使用该对象来进…...
地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...
golang循环变量捕获问题
在 Go 语言中,当在循环中启动协程(goroutine)时,如果在协程闭包中直接引用循环变量,可能会遇到一个常见的陷阱 - 循环变量捕获问题。让我详细解释一下: 问题背景 看这个代码片段: fo…...
通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...
反射获取方法和属性
Java反射获取方法 在Java中,反射(Reflection)是一种强大的机制,允许程序在运行时访问和操作类的内部属性和方法。通过反射,可以动态地创建对象、调用方法、改变属性值,这在很多Java框架中如Spring和Hiberna…...
C++中string流知识详解和示例
一、概览与类体系 C 提供三种基于内存字符串的流,定义在 <sstream> 中: std::istringstream:输入流,从已有字符串中读取并解析。std::ostringstream:输出流,向内部缓冲区写入内容,最终取…...
GitHub 趋势日报 (2025年06月08日)
📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 884 cognee 566 dify 414 HumanSystemOptimization 414 omni-tools 321 note-gen …...
华为云Flexus+DeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建
华为云FlexusDeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建 前言 如今大模型其性能出色,华为云 ModelArts Studio_MaaS大模型即服务平台华为云内置了大模型,能助力我们轻松驾驭 DeepSeek-V3/R1,本文中将分享如何…...
IP如何挑?2025年海外专线IP如何购买?
你花了时间和预算买了IP,结果IP质量不佳,项目效率低下不说,还可能带来莫名的网络问题,是不是太闹心了?尤其是在面对海外专线IP时,到底怎么才能买到适合自己的呢?所以,挑IP绝对是个技…...
招商蛇口 | 执笔CID,启幕低密生活新境
作为中国城市生长的力量,招商蛇口以“美好生活承载者”为使命,深耕全球111座城市,以央企担当匠造时代理想人居。从深圳湾的开拓基因到西安高新CID的战略落子,招商蛇口始终与城市发展同频共振,以建筑诠释对土地与生活的…...
站群服务器的应用场景都有哪些?
站群服务器主要是为了多个网站的托管和管理所设计的,可以通过集中管理和高效资源的分配,来支持多个独立的网站同时运行,让每一个网站都可以分配到独立的IP地址,避免出现IP关联的风险,用户还可以通过控制面板进行管理功…...
