React常用方法汇总【更新中】

文章目录

  • 前言
  • 创建项目
  • 启动命令
  • 列表渲染
  • useEffect 异步函数使用方法
  • useEffect 异步函数清除方法
  • 控制组件显示隐藏
  • axios 安装使用


前言

运行 react 需要先安装 node.js,具体安装步骤可以参考这篇文章 https://blog.csdn.net/weixin_43721000/article/details/134284418


创建项目

npx create-react-app <项目名称>
# npx create-react-app my-app

启动命令

先 cd 到项目目录下

npm start

列表渲染

import React, { useState } from "react"

function App() {
  const [artList, setArtList] = useState([
    {'id': 1, 'title': '百年孤独', 'author': '马尔克斯'},
    {'id': 2, 'title': '老人与海', 'author': '海明威'}
  ])

  return (
    <div>
      {artList.map(item =><li key={item.id}>{item.title}{item.author}</li>)}
    </div>
  );
}

export default App;

在这里插入图片描述


useEffect 异步函数使用方法

useEffect 是异步函数,有三种不同的执行方式:

  1. 监听到页面发生变动就执行此方法
    useEffect(() => {
    	console.log('页面发生变动就执行此方法')
    })
    
  2. 立即执行,且仅执行一次
    useEffect(() => {
    	console.log('仅执行一次')
    }, [])
    
  3. 监听到某个变量产生变化时就执行
    const [count, setCount] = useCount(233)
    useEffect(() => {
    	console.log('count值发生变化时执行')
    }, [count])
    

useEffect 异步函数清除方法

useEffect 函数执行后,可以通过以下几种情况终止执行

  1. 当前组件销毁时终止执行
    useEffect(() => {
    	// 执行逻辑
    	const timer = setInerval(() => {
    		console.log('定时器执行中')
    	}, 1000) 
    
    	// 此方法会在 useEffect 所在组件被销毁时执行
    	return () => {
    		// 清除逻辑
    		clearInterval(timer)
    	}
    	
    }, [])
    
  2. todo

控制组件显示隐藏

import React, { useState } from "react"

// 显示隐藏的组件
function UserInfoElm() {
  return (
    <div>
      <p>姓名:小王</p>
      <p>手机号:138xxxxxxxx</p>
      <p>性别:女</p>
    </div>
  )
}

// 控制显示隐藏的方法
function App() {
  const [isShow, setIsShow] = useState(true)
  const toggleSwitch = () => setIsShow(!isShow)
  return (
    <div>
      {isShow && <UserInfoElm/>}
      <button onClick={toggleSwitch}>点击 显示/隐藏 用户信息</button>
    </div>
  );
}

export default App;


axios 安装使用

  • 安装方法
    npm install axios
    
  • 使用方法
    1. 后端返回数据结构
      {
      	"code": 1,
      	"msg": "好耶",
      	"data": [{
      		"id": 1,
      		"title": "百年孤独",
      		"author": "马尔克斯"
      	}, {
      		"id": 2,
      		"title": "老人与海",
      		"author": "海明威"
      	}]
      }
      
    2. 前端调用代码
      import axios from "axios";
      import React, { useEffect, useState } from "react"
      
      function App() {
        const [artList, setArtList] = useState([])
      
        // 异步执行,立即执行,仅执行一次
        useEffect(() => {
          // 定义请求数据的方法
          async function getArtList() {
            const res = await axios.get('http://127.0.0.1:11237/get_art_list')
            setArtList(res.data.data)  // axios 返回的数据会额外封装一层 data
          }
          // 调用
          getArtList()
        }, [])
        
        // 列表渲染
        return (
          <div>
            {artList.map(item =><li key={item.id}>{item.title}{item.author}</li>)}
          </div>
        );
      }
      
      export default App;
      
      
    在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

掌握这三点软文营销技巧:轻松助力品牌传播

在营销方式层出不穷的今天&#xff0c;软文推广已不再只是简单的文字堆砌&#xff0c;而是成为了品牌与消费者深度沟通的桥梁。随着消费者获取信息的渠道越来越多元化&#xff0c;软文推广也迎来了新的趋势和挑战。今日投媒网将与您分享如何在新时代背景下&#xff0c;提升软文…

人工智能技术应用笔记(十二):搭建自带大模型微信,完美对接GPT-4o,Kimi等大模型,智能体平台Coze也能接

许多朋友对如何搭建自己的微信机器人非常感兴趣。今天就来教大家如何操作。 一、 准备工作 一台电脑或者云服务器&#xff0c;对配置要求不高&#xff0c;一般的电脑就行 大模型API调用的Key&#xff0c;比如GPT-4o&#xff0c;Kimi&#xff0c;Deepseek&#xff08;不知道怎…

个人博客测试用例设计

个人博客测试用例设计 个人博客测试用例 分别从功能、性能、安全、兼容及界面分别展开 个人博客测试用例

工业边缘计算网关在机械制造企业中的应用-天拓四方

随着信息技术的不断发展&#xff0c;工业领域对数据处理和分析的需求日益增长。工业边缘计算网关作为一种新型技术&#xff0c;正逐渐成为工业数字化转型的关键驱动力。本文将通过一个具体案例阐述工业边缘计算网关在工业中的应用&#xff0c;以及其为工业生产带来的显著效益。…

远程桌面有时连接不上,远程桌面时连接不上的七个处理方法

远程桌面连接作为一种方便、高效的远程管理工具&#xff0c;广泛应用于企业办公、技术支持以及在线教育等多个领域。然而&#xff0c;在实际应用中&#xff0c;用户有时会遇到远程桌面连接不上的情况&#xff0c;这不仅影响了工作效率&#xff0c;还可能导致重要任务的延误。因…

Linux系统:线程互斥

Linux系统&#xff1a;线程互斥 线程互斥互斥锁 mutex互斥锁原理 常见的锁死锁自旋锁 spinlock其它锁 线程互斥 讲解线程互斥前&#xff0c;先看到一个抢票案例&#xff1a; class customer { public:int _ticket_num 0;pthread_t _tid;string _name; };int g_ticket 10000…

vue element-ui 车牌号选择组件

实现效果 carnumber.vue <template><div class"car_no_popover"><div class"row_div"><div class"every_div" v-for"item in area"><button click"selectCarNo(item)">{{ item }}</butto…

【GlobalMapper精品教程】086:批量修改符号的样式

跟ArcGIS一样,Globalmapper也可以批量修改符号的样式,如样式、填充颜色、轮廓等等。 文章目录 一、加载实验数据二、土地利用符号化三、批量修改符号样式四、注意事项一、加载实验数据 订阅专栏后,从私信查收专栏配套的完整实验数据包,打开data086.rar中的土地利用数据,如…

基于PaddleDetection的电路板瑕疵检测

文章目录 1. 数据集与框架介绍2. 任务详情3. Cascade R-CNN简介4. 数据分析各类别样本的数量真实框的宽高比真实框在原图的大小比例 5. 相关配置数据增强数据集路径和评估指标学习率和优化器配置预训练CascadeRCNN 的配置日志记录 6. 训练预测7. 参考链接 1. 数据集与框架介绍 …

SpringMVC系列二: 请求方式介绍

RequestMapping &#x1f49e;基本使用&#x1f49e;RequestMapping注解其它使用方式可以修饰类和方法可以指定请求方式可以指定params和headers支持简单表达式支持Ant 风格资源地址配合PathVariable 映射 URL 绑定的占位符注意事项和使用细节课后作业 上一讲, 我们学习的是Spr…

2024年618购物狂欢节买什么最超值!618不可错过的好物清单!

618年中大促再度来临。对于购物爱好者来说&#xff0c;这无疑是一个不容错过的购物盛宴。那么&#xff0c;在这个618&#xff0c;哪些好物值得你重点关注呢&#xff1f;我特地整理了一份推荐清单&#xff0c;这些产品不仅经过我的亲身体验&#xff0c;更以其出色的实用性和高性…

【嵌入式】适配大多数STM32的最小系统设计

大多数的参赛作品以及毕业设计中都仅仅简单的使用STM32F103最小系统板加上洞洞板或面包板。这样的设计虽然可以进行功能演示&#xff0c;但是由于市面上的最小系统板太过简单&#xff0c;并没有发挥出STM32系列MCU的强大功能&#xff0c;而且看起来很不美观&#xff0c;为了在参…

Scott Brinker:API对今天的Martech用户来说「非常重要」 ,但它们对即将到来的人工智能代理浪潮至关重要

API在Martech中非常重要 猜一猜空格应该填什么&#xff1a; _______之于AI代理就像数据之于AI模型 正如你可能从我的标题猜到的那样&#xff0c;答案是API。让我们讨论一下为什么…… 数据是人工智能模型的差异化 在过去的一年半里&#xff0c;人工智能疯狂的超级炒作周期…

阻力支撑相对强度(RSRS)选股系列报告之三

https://download.csdn.net/download/SuiZuoZhuLiu/89447699?spm1001.2014.3001.5503https://download.csdn.net/download/SuiZuoZhuLiu/89447699?spm1001.2014.3001.5503

高薪项目经理都在用的工具,你会几个?

甘特图、里程碑图、看版图、燃尽图、WBS、思维导图、流程图、鱼骨图、清单表、项目日历、关系矩阵、PERT图、决策树、状态表。这些工具&#xff0c;你会几个&#xff1f; 甘特图&#xff08;Gantt Chart&#xff09; 甘特图是一种条形图&#xff0c;用于展示项目任务的时间线&…

所以spring mvc异常处理工作原理是啥

文章目录 spring mvc异常处理&#xff08;源码分析&#xff09;概述原理&#xff08;源码角度&#xff09;模拟debug前期提要分析4个map4个map的初始化为什么需要基于mappedMethods缓存 总结一下 spring mvc异常处理&#xff08;源码分析&#xff09; 概述 spring mvc有下面三…

压测怎么做?如何自动化?盘点各大公司全链路压测方案与实践

本文综合盘点各大公司团队的全链路压测技术方案和实践路径&#xff0c;供大家参考。 一、什么是全链路压测&#xff1f; 全链路压测指的是基于实际的生产业务场景、系统环境&#xff0c;模拟海量的用户请求和数据对整个业务链进行压力测试&#xff0c;并持续调优的过程。常用…

30v-180V降3.3V100mA恒压WT5107

30v-180V降3.3V100mA恒压WT5107 WT5107是一款恒压单片机供电芯片&#xff0c;它可以30V-180V直流电转换成稳定的3.3V直流电&#xff08;最大输出电流300mA&#xff09;&#xff0c;为各种单片机供电。WT5107的应用也非常广泛。它可以用于智能家居、LED照明、电子玩具等领域。比…

功能强大的API函数FindFirstFile使用介绍(附源码)

在处理文件的相关代码中,会频繁使用到Windows系统API函数FindFirstFile,这个函数功能很强大,很多功能都不开它。本文就根据我们在项目中使用该函数的情况,来大概地梳理一下使用FindFirstFile都可以实现哪些常用的功能。 1、FindFirstFile函数声明与WIN32_FIND_DATA结构体 我…

Java的核心类库

引言 在Java编程中&#xff0c;熟练掌握常用类与对象操作是开发的基础。Java的核心类库提供了丰富的功能&#xff0c;可以帮助开发者高效地处理各种编程任务。本文将详细介绍Java字符串操作、集合框架、日期与时间处理等内容&#xff0c;并通过图表和表格进行总结与示范。 字符…