zl程序教程

您现在的位置是:首页 >  Javascript

当前栏目

学习React,从这篇文章开始!

2023-03-20 14:51:10 时间
一、React是什么?

React 是基于 JavaScript 的用户界面库,可灵活组合元素(html标签)并渲染到HTML中某个指定DOM元素下。

JSX 是React定义的一种 标签式 扩展语法,用 JSX 编写的元素和组件,通过预处理器 babel 解析,再交给 React 渲染到HTML中指定节点下,最终形成 HTML 文件。当然React不强制要求使用 JSX ,但 JSX 确实带来了更多便利。JSX怎么使用?详情,看这里!


二、怎么安装和使用React

怎么使用 React 库到我的项目中去?推荐使用 Create React App 创建React项目,用于学习研究,因为它配置了React 运行所需的所有环境,开箱即用,详细安装和使用步骤,详情,看这里!


三、React元素和组件
1、class组件、函数组件

HTML中的标签(div、p等),在 React 中称之为元素,是构成React的最小单位,多个元素可以构成组件,组件分为 class组件函数组件。组件怎么创建和使用,详情,看这里!

2、生命周期

每个组件经历:挂载、更新、销毁,这三个阶段,称之为组件的生命周期。详情,看这里!


四、其他主题及解决方案
1、props

组件(包括函数组件和class组件)间的内置属性,用其可以传递数据给子节点。详情,看这里!


2、Context

用于设置全局变量。详情,看这里!


3、state

class组件的内置对象,用于class组件内部数据更新,譬如可以封装一个Clock组件,每秒更新一次时间。详情,看这里!


4、受控组件

用state来获取和设置输入元素值的组件,称之为受控组件<input type="text">, <textarea><select> 等标签都可用 value 属性,来实现受控组件。详情,看这里!


5、Hook

Hook 是以 use 开头的特殊函数(useState、useEffect等),只能在 函数组件 内部使用。让函数组件 拥有 class组件 才有的功能,譬如 useState 就等同于 class组件中的state对象。Hook是React 16.8 新增特性。详情,看这里!


6、Fragment

无需向 DOM 添加额外节点,即可完成子列表分组功能。详情,看这里!


7、Portal

React节点默认渲染到父节点下,Portal可以让节点渲染到非父节点的其他节点下面。Portal适用场景:当子组件需要从视觉上“跳出”其容器时,譬如对话框、悬浮卡、提示框等。详情,看这里!


8、高阶组件

就是一个函数,接收组件作为参数并返回新组件的过程。将多个组件的相同逻辑代码,抽象到HOC中,让组件更有结构化,更易于复用。HOC不破坏传入组件的特性,只通过组合形成新组件。HOC是纯函数,没有副作用。详情,看这里!


9、ref

ref 可以理解为指向React 元素的变量,方便其他组件访问这个React元素。详情,看这里!


10、事件处理函数

页面交互必然会伴随事件的发生,譬如HTML中的一个button被点击了一下,接下来页面应该怎么反应?就是需要button的onClick事件函数来处理。详情,看这里!


11、列表key属性

当创建列表组件时,必须给每一个元素设置 key 属性,否则会有警告: a key should be provided for list items。如果元素没有key属性,React很难判断元素应该怎么渲染?如果元素有key值,那么React只对匹配key值的元素,进行更改等渲染操作,这样极高提升了运行性能。详情,看这里!


12、错误边界

UI 中 JavaScript 错误不应该导致整个应用崩溃,错误边界就是解决方案(React 16 增加的功能)。详情,看这里!


第三方库对接
性能优化
测试用例

五、相关链接: