React 入门第一天:从Vue到React的初体验

ops/2024/9/20 1:03:42/ 标签: react.js, vue.js, 前端

作为一名合格的前端工程师,怎么能只会Vue呢?学习React不仅是一场新技术的探索,更是对前端开发思维的一次重新审视。在这里,我将分享学习React的心得,希望能帮助那些和我一样从Vue转向React的开发者。

1. 为什么选择React?

在进入学习之前,先了解为什么选择React。React是由Facebook开发和维护的一个开源JavaScript库,用于构建用户界面。它最大的特点是组件化单向数据流,以及引入了独特的JSX语法,这使得React成为了现代前端开发中的一颗明星。

2. 初识React:与Vue的对比

对于Vue开发者来说,React的入门其实并不难,因为它们在很多概念上是相通的。以下是React和Vue在几个关键点上的对比:

a. 组件化
  • Vue:组件是Vue的核心,使用模板(template)来定义组件的结构。
  • React:组件同样是核心,但使用的是JSX来编写组件,这是一种将HTML嵌入JavaScript中的语法。
b. 状态管理
  • Vue:组件状态通过data来管理,并通过双向绑定更新视图。
  • React:组件状态使用useState Hook(或类组件中的state)来管理,状态更新后通过重新渲染组件更新视图。
c. 生命周期
  • Vue:提供了丰富的生命周期钩子,如mountedupdated等。
  • React:通过useEffect Hook(或类组件中的生命周期方法)来处理副作用。

3. 第一个React组件

在了解了基本概念后,我们来动手写第一个React组件。假设我们要创建一个简单的计数器应用。

a. 创建项目

首先,我们可以使用Create React App脚手架快速创建一个React项目:

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

项目创建完成后,你会看到一个初始的React应用页面。

b. 编写计数器组件

接下来,我们创建一个计数器组件:

import React, { useState } from 'react';function Counter() {// 定义一个名为count的状态变量,并初始化为0const [count, setCount] = useState(0);return (<div><h1>计数器:{count}</h1><button onClick={() => setCount(count + 1)}>增加</button></div>);
}export default Counter;

在这个简单的计数器中,我们使用了useState Hook来管理状态,并通过onClick事件处理器更新状态。这个过程与Vue非常相似,只是语法略有不同。

c. 将组件引入到应用中

最后,我们需要将这个组件引入到主应用中:

import React from 'react';
import ReactDOM from 'react-dom';
import Counter from './Counter'; // 引入计数器组件function App() {return (<div className="App"><Counter /></div>);
}ReactDOM.render(<App />, document.getElementById('root'));

运行应用,你会看到一个简单的计数器,点击按钮,数字会递增。

4. 感悟与小结

React的学习第一天,我感受到了它的灵活性和强大的生态系统,特别是在组件化开发和状态管理方面,它与Vue有异曲同工之妙。但同时,JSX的语法和Hooks的使用也是全新的体验,让我意识到React并不仅仅是一个工具,更是一种不同的思维方式。

对于熟悉Vue的开发者来说,React并没有想象中那么难,只要你愿意多动手、多实践,React的学习曲线并不会很陡峭。接下来的学习中,我会继续深入探索React的高级特性,期待能在未来的项目中运用它。

希望这篇文章对那些同样从Vue转向React的开发者有所帮助,如果你有任何疑问或想法,欢迎留言与我交流!


http://www.ppmy.cn/ops/97184.html

相关文章

playbook(剧本)基本应用、playbook常见语法、playbook和ansible操作的编排

playbook(剧本): 是ansible⽤于配置,部署,和管理被控节点的剧本。⽤ 于ansible操作的编排。 使⽤的格式为yaml格式 一、YMAL格式 以.yaml或.yml结尾 ⽂件的第⼀⾏以 "---"开始&#xff0c;表明YMAL⽂件的开始(可选的) 以#号开头为注释 列表中的所有成员都开始于…

思特科技案例:北京欢乐谷光影乐园

01      在北京欢乐谷的亲子领域&#xff0c;藏着一处“面积近400平米&#xff0c;炫酷堪比魔法世界的、美轮美奂的光影空间&#xff0c;做到了“让娃来了不想走&#xff0c;一玩就是一下午”。    思特科技案例&#xff1a;北京欢乐谷光影乐园      02      作…

STM32之SPI读写W25Q128芯片

SPI简介 STM32的SPI是一个串行外设接口。它允许STM32微控制器与其他设备&#xff08;如传感器、存储器等&#xff09;进行高速、全双工、同步的串行通信。通常包含SCLK&#xff08;串行时钟&#xff09;、MOSI&#xff08;主设备输出/从设备输入Master Output Slave Input&…

Godot关于fbx格式文件导入

查看文档fbx格式是支持&#xff0c;看我的文件也是存在&#xff0c;就是在编辑器中文件系统找不到。解决方案如下 确保你开启了fbx导入&#xff0c;之后自动重启就可以导入了&#xff0c;unity的模型也可以用。什么立方体胶囊之类的。

水利机械5G智能制造工厂物联数字孪生平台,推进制造业数字化转型

在当今这个科技日新月异的时代&#xff0c;水利机械行业正经历着一场深刻的变革&#xff0c;其中5G智能制造工厂物联数字孪生平台的引入&#xff0c;无疑是推动制造业数字化转型的重要驱动力。工业物联数字孪生平台是智能制造工厂的核心组成部分&#xff0c;它基于物理世界的真…

高性能日志系统 代理模式构建全局日志器获取接口

日志器获取接口 通过两个函数&#xff0c;用于获取指定名称的日志器和root日志器。两个函数分别通过调用loggerManager的getInstance方法&#xff0c;获取单例的日志管理器对象&#xff0c;通过这种方式&#xff0c;借助日志管理器获取具体的日志器对象。 设计的主要目的&…

打卡学习Python爬虫第三天|python的re模块的使用

如何在python程序中使用正则表达式&#xff1f;就是使用re模块 re模块使用&#xff1a; 1、findall查找所有&#xff0c;返回list list re.findall("n","I love learning English and Chinese!") print(list) # 输出结果&#xff1a;[n,n,n,n,n] list…

Epic Games 商店面向欧盟 iPhone 用户上线

Epic Games Store 终于在欧盟推出&#xff0c;为玩家提供了不通过 App Store 就能在 iPhone上访问游戏的途径。在经历了漫长而昂贵的关于支付和竞争对手应用程序店面的法律战&#xff0c;以及公证方面的麻烦之后&#xff0c;Epic Games 成功地为App Store 带来了一个数字店面。…

【pyqt5】QLineEdit中的文本输入限制方式,输入校验规则的应用详解

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

【Pyspark-驯化】一文搞懂Pyspark中表连接的使用技巧

【Pyspark-驯化】一文搞懂Pyspark中表连接的使用技巧 本次修炼方法请往下查看 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我工作、学习、实践 IT领域、真诚分享 踩坑集合&#xff0c;智慧小天地&#xff01; &#x1f387; 相关内容文档获取 微信公众号 &…

重复的DNA序列

题目链接 重复的DNA序列 题目描述 注意点 0 < s.length < 10^5s[i]‘A’、‘C’、‘G’ or ‘T’返回所有在 DNA 分子中出现不止一次的 长度为 10 的序列(子字符串) 解答思路 使用一个大小为10的滑动窗口存储该区间内的字符组成的字符串&#xff0c;使用哈希表存储任…

如何评估Redis的性能

导语 Redis是一款高性能的内存数据库&#xff0c;被广泛用于缓存、持久化、消息队列等各种场景。为了确保Redis的高性能运行&#xff0c;评估Redis的性能是非常重要的。本文将介绍如何评估Redis的性能&#xff0c;并从问题解决的角度探讨如何优化Redis的性能。 1. 性能评估指…

【前端基础篇】HTML零基础速通

文章目录 前言HTML结构认识HTML标签 HTML文件基本结构标签层次结构 快速生成代码框架HTML常见标签注释标签标题标签段落标签换行标签格式化标签图片标签超链接标签表格标签基本使用合并单元格 列表标签表单标签form标签input标签 label标签select标签textarea标签无语义标签 HT…

基于Python flask的岗位招聘数据分析系统,应用Python、Flask框架、Pyecharts、Wordcloud等技术

基于Python Flask的岗位招聘数据分析系统旨在为企业人力资源部门和求职者提供一个全面的数据分析平台&#xff0c;通过对招聘数据的深度挖掘和可视化展示&#xff0c;帮助用户做出更明智的决策。该系统采用了Python、Flask框架&#xff0c;并结合Pyecharts、Wordcloud等技术&am…

雪花算法理解(1高位+41位时间戳+10位机器位+12位自增序号) 及其使用豆包帮助下一个解决了时钟回拨的代码

背景&#xff1a; 为啥需要雪花算法呢&#xff1f; 1.我们是不希望用UUID的&#xff0c;因为它是字符串&#xff0c;不利于索引的建立。 2.字符串内存占用大。 3.游戏中&#xff0c;我们希望生成的id是有意义的&#xff0c;我们可以根据id去反推出一些业务信息。所以根据唯一的…

三生随记——暴雨之夜

第一章&#xff1a;暴雨将至 乌云如墨般在天空中翻涌&#xff0c;沉闷的雷声从远方传来&#xff0c;预示着一场暴雨即将降临。在这个繁华都市的角落里&#xff0c;年轻的画家林晓独自坐在她的工作室里&#xff0c;望着窗外阴沉的天色&#xff0c;心中涌起一股莫名的不安。 林…

微信小程序的遍历和事件的简单案例

遍历和事件的简单案例 在微信小程序中&#xff0c;你可以通过为组件添加事件来实现交互功能。当用户触发这些事件时&#xff0c;小程序会执行相应的处理函数。下面是一个示例&#xff0c;展示如何在微信小程序中遍历标签并为其添加点击事件&#xff1a; <view><view …

一起学习LeetCode热题100道(49/100)

49.二叉树的最近公共祖先(学习) 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#xff0c;最近公共祖先表示为一个节点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可能大&#…

@DateTimeFormat和@JsonFormat

DateTimeFormat 用于接收前端传入的参数&#xff0c;变成自己想要的格式 JsonFormat用于格式化后端返回给前端的参数 DateTimeFormat(pattern "yyyy-MM-dd HH:mm:ss") JsonFormat(pattern "yyyy-MM-dd HH:mm:ss", timezone "GMT8") private …

微服务架构

应用架构的变迁 谈到微服务之前&#xff0c;首先我们通过下面图片简单了解一下应用架构的变迁 单体架构在小型项目和早期阶段可能非常有效&#xff0c;但随着应用程序的增长和复杂性的增加&#xff0c;它逐渐暴露出可扩展性差、可维护性差、持续集成和持续部署&#xff08;CI…