React18从入门到实战

news2025/2/24 18:11:20

文章目录

  • 一、React环境的搭建
  • 二、项目文件的介绍
    • (1)package.json,他是项目存放依赖包的地方,里面包括了一些项目核心包及下载的其他插件包
    • (2)src文件夹是项目源码目录,平时开发页面就在其中
    • (3).public文件
    • (4)node_modules
  • 三. JSX
    • 什么是JSX
    • JSX中使用js表达式
    • JSX实现列表渲染
    • JSX实现条件渲染
    • if else if else(可以根据多种情况来判断显示模板内容)
  • 四. 事件绑定
    • 基础绑定
    • 获取事件对象参数
  • 五. React的组件
  • 六. useState
    • 基础使用
    • 自增器小例子:
    • useState的特点
  • react组件样式
  • B站评论案例


一、React环境的搭建

创建react项目的更多方式

使用npx react-create-app react-basic项目名称创建

在这里插入图片描述

启动项目

 npm start

打包项目

 npm run build

启动测试运行项目

npm test

将项目中隐藏的webpack配置释放出

npm run eject

二、项目文件的介绍

(1)package.json,他是项目存放依赖包的地方,里面包括了一些项目核心包及下载的其他插件包

 "dependencies": {
    "@testing-library/jest-dom": "^5.17.0",
    "@testing-library/react": "^13.4.0",
    "@testing-library/user-event": "^13.5.0",
    "react": "^18.2.0",
    "react-dom": "^18.2.0",
    "react-scripts": "5.0.1",
    "web-vitals": "^2.1.4"
  },

以上就是package文件中存放项目核心包的地方

"scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },

这个地方是项目中可执行的一些命令

(2)src文件夹是项目源码目录,平时开发页面就在其中

将其中除去index.js和app.js的文件全部删掉并分别进入index和app将其中的引用代码清除,保留一个干净的目录开始练习

index.js文件是整个项目的入口,运行的起点

index.js删除后
//react必要的俩个核心包
import React from 'react';
import ReactDOM from 'react-dom/client';

//导入项目的根组件
import App from './App';

//把app根组件渲染到id为root的节点上(节点在public的index.html中)
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<App />);

app.js文件是整个项目的根组件

app.js删除后
//app->index.js->public/index.htnl(root)路径
function App() {
  return (
    <div className="App">
          this is app
    </div>
  );
}

export default App;

(3).public文件

favicon.ico

public文件里面通常放着一些静态资源。例如.ico结尾的文件即为我们项目运行成功后,在浏览器页签中所展示的icon图标,但是我们不能将其替换为png或者jpg格式的文件,如果想替换的话就必须替换为ico格式的文件。

index.html

项目的入口文件,引用了第三方类库啊,还可以引入cdn,或者样式,但是其中的div id=“root”>是项目的总容器,所有的内容存储在这个容器中。这个容器有且只能有一个。且在项目的其他地方我们不建议往这个容器中加入我们待渲染的组件和页面,因为在root中我们添加的是APP,如果我们再添加其他元素进去,会将我们添加的APP顶掉

manifest.json

该文件是一个套壳的配置文件,当我们的项目需要在手机端运行时,就需要在这个文件里面进行配置。通过安卓和苹果的应用程序都需要使用专门的开发语言进行开发,因此如果我们想使用html来进行简单的移动端页面的开发,就需要进行套壳。这种就在这里不进行过多的讲解。

Robots.txt

该文件是屏蔽文件,主要是为了防止爬虫来进行页面数据的爬去,可以参考如下网站的简介 https://blog.csdn.net/weixin_30955341/article/details/94896204

(4)node_modules

该目录下所对应的文件时我们所安装的包文件

三. JSX

什么是JSX

JSX是js和xml(html)的缩写1,表示在js代码中能便编写html模板结构,它是react中编写ui模板的方式

在这里插入图片描述

本质并不是标准的js语法,它是js语法的扩展,浏览器本身不能直接识别,需要通过解析工具(babel)解析后才能在浏览器运行

在这里插入图片描述

jsx优点:

1.html的声明式模板写法
2.js的可编程能力

JSX中使用js表达式

通过大括号语法{}识别js中的表达式,比如常见的变量,函数调用,方法调用等

1. 使用引号传递字符串
2. 使用js变量
3. 函数调用和方法调用
4. 使用js对象
在这里插入图片描述

const count  = 100
function getName (){
  return 'zhang'
}
function App() {
  return (
    <div className="App">
          this is app
          {/* {使用引号传递字符串} */}
          {'this is message'}
          {/* 识别js变量 */}
          {count}
          {/* 函数调用和方法调用 */}
          {getName()}
          {new Date().getDate()}
          {/* 使用js对象 */}
          <div style={{color:'red'}}>red div</div>
          
    </div>
  );
}
export default App;

JSX实现列表渲染

在这里插入图片描述

const list = [
  {id:0,name:"vue"},
  {id:1,name:"react"},
  {id:2,name:"微信小程序"}
]
function App() {
  return (
    <div className="App">
         <ul>
          {list.map(item=><li key={item.id}>{item.name}</li>)}
         </ul>
    </div>
  );
}

export default App;

JSX实现条件渲染

逻辑运算符&&(只需要根据变量判断是否显示隐藏)

const flag = true
function App() {
  return (
    <div className="App">
         {flag&&<span>flag为true就显示flase不显示</span>}
    </div>
  );
}

export default App;

三元表达式(可以根据变量来显示true的模板内容还是false的模板内容)

const flag = false
function App() {
  return (
    <div className="App">
         {flag?<span>loading...</span>:<span>no loading</span>}
    </div>
  );
}

export default App;

if else if else(可以根据多种情况来判断显示模板内容)

// 定义文章类型
const articleType = 2
function getArticleType(){
  if(articleType===0){
    return <div>我是无图文章</div>
  }else if(articleType===1){
    return <div>我是单图文章</div>
  }else if(articleType===2){
    return <div>我是双图文章</div>
  }else{
    return <div>我是三图或者更多图的文章</div>
  }
}
function App() {
  return (
    <div className="App">
      {/* 通过调用函数来渲染不同模板 */}
      {getArticleType()}
    </div>
  );
}

export default App;

在这里插入图片描述

四. 事件绑定

基础绑定


function App() {
  function handClick(){
    alert('我被点击了')
  }
  return (
    <div className="App">
      <button onClick={handClick}>点我</button>
    </div>
  );
}

export default App;

在这里插入图片描述

获取事件对象参数

默认事件参数


function App() {
  const handClick=(e)=>{
    console.log('我被点击了',e)
  }
  return (
    <div className="App">
      <button onClick={handClick}>点我</button>
    </div>
  );
}

export default App;

自定义参数传递

语法:事件绑定的位置改成箭头函数的写法,在执行click函数实际处理业务函数时候传递实参

在这里插入图片描述

function App() {
  const handClick=(name)=>{
    console.log('我被点击了',name)
  }
  return (
    <div className="App">
      <button onClick={()=>handClick('掌门')}>点我</button>
    </div>
  );
}

export default App;

五. React的组件

组件是什么

一个组件就是用户界面的一部分,他有自己的逻辑和外观,组件之间可以相互嵌套也可以复用多次

React组件

在react中,一个组件就是首字母大写的函数,内部存放了组建的逻辑和视图,渲染组件只需要将组件当成一个标签书写即可

在这里插入图片描述


const Button=()=>{
  //业务组件逻辑
  return <button>click mo</button>
}
function App() {
  
  return (
    <div className="App">
    {/* 自闭合 */}
    <Button/>
    {/* 成对标签 */}
    <Button></Button>
    </div>
  );
}

export default App;

六. useState

基础使用

useState是一个react hook函数,它允许我们向一个组件添加一个状态变量,从而控制组件的渲染效果

const [count setCount] = useState(0)

1. useState是一个函数返回值是一个数组

2. 数组中第一个参数是状态变量,第二个参数是set用来修改状态变量

3. useState的参数做为count的初始值

自增器小例子:


// 实现一个计数器点击自增
import {useState} from 'react'
function App() {
  // 1.调用useState添加一个状态变量
  //count 状态变量
  // setCount修改状态变量的方法
  const [count,setCount]=useState(0)
  // 2.点击事件回调
  const handleClick=()=>{
    //作用:
    // 1.用传入的新值修改count
    // 2.重新使用新的count渲染视图
    setCount(count+1)
  }
  return (
    <div className="App">
        <button onClick={handleClick}>{count}</button>
    </div>
  );
}

export default App;

useState的特点

在react中,状态被认为是只读的,我们应该替换他而不是修改它,直接修改状态不能引起视图更新

修改变量状态

let [count,setCount] = useState(0)
const handleClick=()=>{
	//直接修改无法引起视图更新
	count++
	console.log(count
}
const handleClick=()=>{
//作用:
    // 1.用传入的新值修改count
    // 2.重新使用新的count渲染视图
    setCount(count+1)
 }

修改对象状态

对于对象类型的状态变量,应该始终传给set方法一个全新的对象进行修改


import {useState} from 'react'
function App() {
  // 1.调用useState添加一个状态变量
  //count 状态变量
  // setCount修改状态变量的方法
  const [form,setForm]=useState({name:"张"})
  // 2.点击事件回调
  const changeForm=()=>{
    //作用:
    // 1.用传入的新值修改count
    // 2.重新使用新的count渲染视图
    setForm({
      ...form,
      name:"赵"
    })
  }
  return (
    <div className="App">
        <button onClick={changeForm}>修改formm{form.name}</button>
    </div>
  );
}

export default App;

react组件样式

命名类名方式需要使用className

import './index.css'
<div className="top"></div>

index.css中
.top{
	width:100px;
	height:100px;
	background:red;
}

行内方式

直接写版本

<div style="width100px;height:100px;">111</div>

简洁版本

const style={
	width:"100px",
	height:"100px"
}

<div style={style}>111</div>

B站评论案例

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何成为一名优秀的工程师下

身为工程师&#xff0c;理所当然要重视实践&#xff0c;自然科学不管发展到何时都离不开实验。 电子学本身就是 为了指导工程实践。所以不要谈空洞的理论。现在很多毕业生都面临这样的问题&#xff0c;总是谈一些空洞的理论&#xff0c;甚至错误的但还不以为然的理论。实践可以…

【软考】23种设计模式详解,记忆方式,并举例说明

23种设计模式详解&#xff0c;举例说明 一、创建型模式1.1、抽象工厂模式&#xff08;Abstract Factory&#xff09;1.1.1、简介1.1.2、意图与应用场景1.1.3、结构1.1.4、优缺点1.1.4、示例代码&#xff08;简化版&#xff09; 1.2、建造者模式&#xff08;Builder&#xff09;…

MySQL主从的介绍与应用

mysql主从 文章目录 mysql主从1. 主从简介1.1 主从作用1.2 主从形式 2. 主从复制原理3. 主从复制配置3.1 mysql安装&#xff08;两台主机安装一致&#xff0c;下面只演示一台主机操作&#xff09;3.2 mysql主从配置3.2.1 确保从数据库与主数据库里的数据一样3.2.2 在主数据库里…

34-4 CSRF漏洞 - CSRF跨站点请求伪造

一、漏洞定义 CSRF(跨站请求伪造)是一种客户端攻击,又称为“一键式攻击”。该漏洞利用了Web应用程序与受害用户之间的信任关系,通过滥用同源策略,使受害者在不知情的情况下代表攻击者执行操作。与XSS攻击不同,XSS利用用户对特定网站的信任,而CSRF则利用了网站对用户网页…

vscode教程

个人笔记&#xff08;整理不易&#xff0c;有帮助点个赞&#xff09; 笔记目录&#xff1a;学习笔记目录_pytest和unittest、airtest_weixin_42717928的博客-CSDN博客 个人随笔&#xff1a;工作总结随笔_8、以前工作中都接触过哪些类型的测试文档-CSDN博客 目录 一&#xff1a…

【SpringBoot3】SpringBoot入门

需求&#xff1a;使用 SpringBoot 开发一个web应用&#xff0c;浏览器发起请求 /hello后&#xff0c;给浏览器返回字符串 “hello world "。 步骤 ①. 创建Maven工程 ②. 导入spring-boot-stater-web起步依赖 <dependency> <groupId>org.springframework…

每天学习一个Linux命令之curl

每天学习一个Linux命令之curl 在Linux系统中&#xff0c;有很多有用的命令可以帮助我们与网络进行交互。一个非常常用的命令是curl&#xff0c;它是一个功能强大的工具&#xff0c;可用于发送、接收和处理各种网络请求。本文将详细介绍在Linux下使用curl命令的各种选项及其用法…

IntelliJ IDEA - Since Maven 3.8.1 http repositories are blocked

问题描述 新下载的 IDEA 在构建项目时&#xff0c;在下载引用的包时出现 “Since Maven 3.8.1 http repositories are blocked” 的问题。 原因分析 从 Maven 3.8.1 开始&#xff0c;不再支持 http 的包了。由于现在对网络安全的日益重视&#xff0c;都在向 https 转变&#…

虚拟M的改进

之前为了保留老习俗&#xff0c;虚拟M采用了和M调用一样的约定&#xff0c;这样的好处是习惯上保持一致&#xff0c;小伙伴提出现在是java了&#xff0c;还这样约定方法太啰嗦&#xff0c;确实是有点啰嗦&#xff0c;进行了改进。 改进为三个参数的&#xff0c;方法可以写在任…

SQLite 4.9的 OS 接口或“VFS”(十三)

返回&#xff1a;SQLite—系列文章目录 上一篇:SQLite字节码引擎&#xff08;十二&#xff09; 下一篇:SQLite 4.9的虚拟表机制(十四) 1. 引言 本文介绍了 SQLite OS 可移植性层或“VFS” - 模块位于 SQLite 实现堆栈底部 提供跨操作系统的可移植性。 VFS是Virtual File…

政安晨:【Keras机器学习实践要点】(二十)—— 使用现代 MLP 模型进行图像分类

目录 简介 设置 准备数据 配置超参数 建立分类模型 定义实验 使用数据增强 将补丁提取作为一个图层来实施 将位置嵌入作为一个图层来实施 MLP 混频器模型 FNet 模式 gMLP 模式 实施 gMLP 模块 政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐…

【Leetcode每日一题】 动态规划 - LCR 166. 珠宝的最高价值(难度⭐⭐)(52)

1. 题目解析 题目链接&#xff1a;LCR 166. 珠宝的最高价值 这个问题的理解其实相当简单&#xff0c;只需看一下示例&#xff0c;基本就能明白其含义了 2.算法原理 想象一下&#xff0c;你正在玩一个寻宝游戏&#xff0c;游戏地图是一个二维网格&#xff0c;每个格子都藏有一…

神经网络中的超参数调整

背景 在深度神经网络学习和优化中&#xff0c;超参数调整一项必备技能&#xff0c;通过观察在训练过程中的监测指标如损失loss和准确率来判断当前模型处于什么样的训练状态&#xff0c;及时调整超参数以更科学地训练模型能够提高资源利用率。在本研究中使用了以下超参数&#x…

Golang 开发实战day08 - Multiple Return values

Golang 教程08 - Multiple Return values 1. Multiple return values 1.1 如何理解多个返回值&#xff1f; Go语言中的多返回值&#xff0c;就像你听了一首歌曲yellow&#xff0c;可以从歌曲里反馈出忧郁和害羞&#xff01;Goland的多个返回值就类似于如此&#xff0c;设定一…

vue实现验证码验证登录

先看效果&#xff1a; 代码如下&#xff1a; <template><div class"container"><div style"width: 400px; padding: 30px; background-color: white; border-radius: 5px;"><div style"text-align: center; font-size: 20px; m…

如何用Python编写简单的网络爬虫(页面代码简单分析过程)

一、什么是网络爬虫 在当今信息爆炸的时代&#xff0c;网络上蕴藏着大量宝贵的信息&#xff0c;如何高效地从中获取所需信息成为了一个重要课题。网络爬虫&#xff08;Web crawler&#xff09;作为一种自动化工具&#xff0c;可以帮助我们实现这一目标&#xff0c;用于数据分析…

Vscode连接WSL2当中的jupyter

主要解决办法参考自这篇博客 1. 在WSL当中安装jupyter 这个随便找一篇博客即可&#xff0c;比如这篇&#xff0c;也可以根据现有的环境参考其它博客内容 2. 使用jupyter创建一个虚拟环境 首先激活想要添加的虚拟环境后&#xff0c;输入命令安装库: pip install ipykernel …

免费全开源,功能强大的多连接数据库管理工具:DbGate

DbGate&#xff1a;您的全能数据库指挥中心&#xff0c;一站式免费开源解决方案&#xff0c;无缝连接并管理多款主流数据库&#xff0c;让复杂的数据世界变得轻松易控! - 精选真开源&#xff0c;释放新价值。 概览 DbGate 是跨平台的数据库管理器。支持 MySQL、PostgreSQL、SQ…

gin框架底层

gin框架底层 gin的背景和使用 这里蓝色的是gin增强的内容&#xff0c;红色的是为了支持增强的内容添加的东西&#xff0c;黄色的是原来的net/http库Gin框架是基于Go语言的net/http标准库构建的&#xff0c;它提供了一个gin.Engine对象&#xff0c;这个对象实现了http.Handler接…

零代码编程:用kimichat打造一个最简单的window程序

用kimichat可以非常方便的自动生成程序代码&#xff0c;有些小程序可能会频繁使用&#xff0c;如果每次都在vscode中执行就会很麻烦。常用的Python代码&#xff0c;可以直接做成一个window程序&#xff0c;点击就可以打开使用&#xff0c;方便很多。 首先&#xff0c;把kimich…