React | 认识React开发

简介: React | 认识React开发

一、React的介绍和特点

React的介绍

  • React是什么?
  • React: 用于构建用户界面的JavaScript库;
  • 3009a4fb81ea4c99abca9d2338056759.png

React的特点 - 声明式编程

  • 声明式编程:
  • 声明式编程是目前 整个大前端开发的模式: Vue React Flutter SwiftUI
  • 它允许我们 只需要维护自己的状态,当状态改变时,React可以根据最新的状态去渲染我们的UI界面

React的特点 - 组件化开发

  • 组件化开发:
  • 组件化开发页面是目前 前端的流行趋势, 我们会将复杂的界面拆分成一个个小的组件;

React的特点 - 多平台适配

  • 多平台适配:
  • 2013年,发布之初主要是开发Web页面
  • 2015年,推出ReactNative,用于开发移动端跨平台;
  • 2017年,推出ReactVR,用于开发虚拟现实Web应用程序

二、Hello React

Hello React案例

  • 在界面显示一个文本: Hello React
  • 点击下方的按钮,文本改变为:Hello World!


  • 第一步:通过React现实一个Hello React
  • 我们编写React的script代码中,必须添加type="text/babel",可以让babel解析jsx的语法

0f74cc83ac3e4a218292b2b7f29dce3b.png

  • ReactDOM.createRoot函数:用于创建一个React根,之后渲染的内容会包含在这个根中
  • 参数:将渲染的内容,挂载到哪一个HTML元素上
  • 这里我们已经定义一个id为root的div


  • root.render函数:
  • 参数:要渲染的根组件


  • 通过{}语法来引入外部的变量或表达式

三、React开发依赖分析

React的开发依赖

  • 开发React必须依赖三个库:
  • react:包含react所必须的核心代码
  • react-dom:react渲染在不同平台所需要的核心代码
  • babel:将jsx转换成React代码的工具


  • 第一次接触React会被繁琐的依赖搞蒙
  • 对于Vue来说,我们只是依赖一个Vue.js文件即可,但是react居然要依赖三个包
  • 这三个库是 各司其职的,目的就是让每一个库只单纯做自己的事情
  • 在React的0.14版本之前是没有react-dom这个概念的,所有功能都包含在react中;


  • 为什么要进行拆分?因为react-native
  • react包中包含了react web和react-native所共同拥有的核心代码
  • react-dom针对web和native所完成的事情不同
  • web端:react-dom会将jsx最终渲染成真实的DOM,显示在浏览器中
  • native端:react-dom会将jsx最终渲染成原生的控件(如Android中的Button,IOS中的UIButton)

Babel和React的关系

  • babel是什么?
  • 又名 Babel.js
  • 目前前段使用非常广泛的编译器,转移器
  • 如当下很多浏览器并不支持ES6的语法,但是确实ES6的语法非常简洁和方便,我们开发时希望使用它们.
  • 那么编写源码时我们就可以使用ES6来编写,之后通过Babel工具,将ES6转成大多数浏览器都支持的ES5的语法


  • React和Babel的关系:
  • 开发React其实可以不适用babel
  • 前提是我们自己使用React.createElement来编写源代码,他编写的代码 非常的繁琐和可读性差.
  • 那么我们就可以直接编写 jsx的语法,并且让 babel帮助我们转换成React.createElement

四、React组件化的封装

Hello React - 组件化开发

  • 我们可以将其封装成一个组件:
  • root.render 参数 是一个HTML元素或一个组件
  • 我们可以先将之前的业务逻辑封装到一个组件中,然后传入到ReactDOM.render函数中的第一个参数
  • 在React中,怎么封装一个组件? 使用 类|函数式 的方式进行封装(这里先使用类)
  • 定义一个类 (类名大写,组件的名称必须大写,小写会被认为是HTML元素),继承自 React.Component
  • 实现当前组件的render函数
  • render当中返回的jsx内容,就是之后React会帮助我们渲染的内容

7b019f014feb45358b279616574c5c33.png

组件化 - 数据依赖

  • 组件化问题:数据应该定义在哪里?


  • 在组件中的数据,我们分为两类:
  • 参与界面更新的数据:当数据变量时,需要更新组件渲染的内容
  • 不参与界面更新的数据:当数据变量时,不需要更新组件渲染的内容


  • 参与界面更新的数据我们称为 参与数据流,这个数据定义在当前对象的state中
  • 可以通过在构造函数中 this.state = {定义的数据},必须得是state
  • 当我们的数据发生变化时,可以调用this.setState来更新数据,并通知React进行update操作
  • 在进行update操作时,就会重新调用render函数,并使用最新数据,来渲染界面

9b997f3c42f24cec929af1fcb9bf0421.png

组件化 - 事件绑定

  • 事件绑定中的this
  • 在类中直接定义一个函数,并将这个函数绑定到元素的onClick事件上,当前这个函数的this指向谁?


  • 默认情况下是undefined
  • 为什么是undefined
  • 因为在正常的DOM操作,监听点击,监听函数中的this其实是节点对象
  • 这次因为React并不是直接渲染为真实DOM,我们编写的这个对象只是一个语法糖,它的本质React的Element对象
  • 那么在这里发生监听的时候,react在执行函数时并没有绑定this,默认情况就是undefined


  • 我们在绑定的函数中,可能想要使用当前对象,如执行this.setState函数,就必须拿到当前对象的this
  • 我们需要在传入函数时,给函数绑定this
  • 如button
  • 改变文本









相关文章
|
3月前
|
前端开发 JavaScript API
React开发需要了解的10个库
本文首发于微信公众号“前端徐徐”,介绍了React及其常用库。React是由Meta开发的JavaScript库,用于构建动态用户界面,广泛应用于Facebook、Instagram等知名网站。文章详细讲解了Axios、Formik、React Helmet、React-Redux、React Router DOM、Dotenv、ESLint、Storybook、Framer Motion和React Bootstrap等库的使用方法和应用场景,帮助开发者提升开发效率和代码质量。
145 4
React开发需要了解的10个库
|
6月前
|
前端开发 JavaScript 安全
TypeScript在React Hooks中的应用:提升React开发的类型安全与可维护性
【7月更文挑战第17天】TypeScript在React Hooks中的应用极大地提升了React应用的类型安全性和可维护性。通过为状态、依赖项和自定义Hooks指定明确的类型,开发者可以编写更加健壮、易于理解和维护的代码。随着React和TypeScript的不断发展,结合两者的优势将成为构建现代Web应用的标准做法。
|
5月前
|
设计模式 存储 前端开发
React开发设计模式及原则概念问题之自定义Hooks的作用是什么,自定义Hooks设计时要遵循什么原则呢
React开发设计模式及原则概念问题之自定义Hooks的作用是什么,自定义Hooks设计时要遵循什么原则呢
|
3月前
|
前端开发 JavaScript 开发者
React 组件化开发最佳实践
【10月更文挑战第4天】React 组件化开发最佳实践
73 4
|
4月前
|
XML 移动开发 前端开发
使用duxapp开发 React Native App 事半功倍
对于Taro的壳子,或者原生React Native,都会存在 `android` `ios`这两个文件夹,而在duxapp中,这些文件夹的内容是自动生成的,那么对于需要在这些文件夹中修改的配置内容,例如包名、版本号、新架构开关等,都通过配置文件的方式配置了,而不需要需修改具体的文件
|
4月前
|
资源调度 JavaScript 前端开发
使用vite+react+ts+Ant Design开发后台管理项目(二)
使用vite+react+ts+Ant Design开发后台管理项目(二)
|
5月前
|
开发者 自然语言处理 存储
语言不再是壁垒:掌握 JSF 国际化技巧,轻松构建多语言支持的 Web 应用
【8月更文挑战第31天】JavaServer Faces (JSF) 框架提供了强大的国际化 (I18N) 和本地化 (L10N) 支持,使开发者能轻松添加多语言功能。本文通过具体案例展示如何在 JSF 应用中实现多语言支持,包括创建项目、配置语言资源文件 (`messages_xx.properties`)、设置 `web.xml`、编写 Managed Bean (`LanguageBean`) 处理语言选择,以及使用 Facelets 页面 (`index.xhtml`) 显示多语言消息。通过这些步骤,你将学会如何配置 JSF 环境、编写语言资源文件,并实现动态语言切换。
51 1
|
5月前
|
JavaScript 前端开发 安全
[译] 使用 TypeScript 开发 React Hooks
[译] 使用 TypeScript 开发 React Hooks
|
5月前
|
移动开发 前端开发 JavaScript
"跨界大战!React Native、Weex、Flutter:三大混合开发王者正面交锋,揭秘谁才是你移动应用开发的终极利器?"
【8月更文挑战第12天】随着移动应用开发的需求日益增长,高效构建跨平台应用成为关键。React Native、Weex与Flutter作为主流混合开发框架各具特色。React Native依托Facebook的强大支持,以接近原生的性能和丰富的组件库著称;Weex由阿里巴巴开发,性能优越尤其在大数据处理上表现突出;Flutter则凭借Google的支持及独特的Dart语言和Skia渲染引擎,提供出色的定制能力和开发效率。选择时需考量项目特性、团队技能及生态系统的成熟度。希望本文对比能助你做出最佳决策。
186 1
|
5月前
|
前端开发
React——开发调式工具安装【五】
React——开发调式工具安装【五】
41 0
React——开发调式工具安装【五】