react框架知识点

react框架知识点
1、React入门:React简介。官网:英文官网: https://reactjs.org/。中文官网: https://react.docschina.org。介绍描述:用于动态构建用户界面的 JavaScript 库(只关注于视图)。由Facebook开源。React的特点:声明式编码,组件化编码。React Native 编写原生应用。高效(优秀的Diffing算法)。React高效的原因:使用虚拟(virtual)DOM, 不总是直接操作页面真实DOM。DOM Diffing算法, 最小化页面重绘。
1、React的基本使用
相关js库:react.js:React核心库。react-dom.js:提供操作DOM的react扩展库。babel.min.js:解析JSX语法代码转为JS代码的库。虚拟DOM与真实DOM。React提供了一些API来创建一种 “特别” 的一般js对象,const VDOM = React.createElement(‘xx’,{id:‘xx’},‘xx’)。上面创建的就是一个简单的虚拟DOM对象,虚拟DOM对象最终都会被React转换为真实的DOM。我们编码时基本只需要操作react的虚拟DOM相关数据, react会转换为真实DOM变化而更新界。
2、React JSX
JSX:全称: JavaScript XML。react定义的一种类似于XML的JS扩展语法: JS + XML本质是React.createElement(component, props, …children)方法的语法糖。作用: 用来简化创建虚拟DOM。写法:var ele = 

Hello JSX!

。注意1:它不是字符串, 也不是HTML/XML标签,注意2:它最终产生的就是一个JS对象,标签名任意: HTML标签或其它标签,标签属性任意: HTML标签属性或其它。
3、基本语法规则
遇到 <开头的代码, 以标签的语法解析: html同名标签转换为html同名元素, 其它标签需要特别解析。遇到以 { 开头的代码,以JS语法解析: 标签中的js表达式必须用{ }包含
4、babel.js的作用
浏览器不能直接解析JSX代码, 需要babel转译为纯JS的代码才能运行,只要用了JSX,都要加上type=“text/babel”, 声明需要babel来处理
5、渲染虚拟DOM(元素)
语法: ReactDOM.render(virtualDOM, containerDOM)。作用: 将虚拟DOM元素渲染到页面中的真实容器DOM中显示。参数说明:参数一: 纯js或jsx创建的虚拟dom对象,参数二: 用来包含虚拟DOM元素的真实dom元素对象(一般是一个div)
6、模块与组件、模块化与组件化的理解
模块理解:向外提供特定功能的js程序, 一般就是一个js文件。为什么要拆成模块:随着业务逻辑增加,代码越来越多且复杂。作用:复用js, 简化js的编写, 提高js运行效率。组件理解:用来实现局部功能效果的代码和资源的集合(html/css/js/image等等)。为什么要用组件: 一个界面的功能更复杂。作用:复用编码, 简化项目编码, 提高运行效率。模块化:当应用的js都以模块来编写的, 这个应用就是一个模块化的应用。组件化:当应用是以多组件的方式实现, 这个应用就是一个组件化的应用

7、React面向组件编程
2.1. 基本理解和使用
2.1.1. 使用React开发者工具调试
2.1.3. 注意
1.组件名必须首字母大写
2.虚拟DOM元素只能有一个根元素
3.虚拟DOM元素必须有结束标签
2.1.4. 渲染类组件标签的基本流程
1.React内部会创建组件实例对象
2.调用render()得到虚拟DOM, 并解析为真实DOM
3.插入到指定的页面元素内部
2.2. 组件三大核心属性1: state
2.2.1. 效果
需求: 定义一个展示天气信息的组件
1.默认展示天气炎热 或 凉爽
2.点击文字切换天气

2.2.2. 理解
1.state是组件对象最重要的属性, 值是对象(可以包含多个key-value的组合)
2.组件被称为"状态机", 通过更新组件的state来更新对应的页面显示(重新渲染组件)
2.2.3. 强烈注意
1.组件中render方法中的this为组件实例对象
2.组件自定义的方法中this为undefined,如何解决?
a)强制绑定this: 通过函数对象的bind()
b)箭头函数
3.状态数据,不能直接修改或更新
2.3. 组件三大核心属性2: props
2.3.1. 效果
需求: 自定义用来显示一个人员信息的组件
1.姓名必须指定,且为字符串类型;
2.性别为字符串类型,如果性别没有指定,默认为男
3.年龄为字符串类型,且为数字类型,默认值为18
2.3.2. 理解
1.每个组件对象都会有props(properties的简写)属性
2.组件标签的所有属性都保存在props中
2.3.3. 作用
1.通过标签属性从组件外向组件内传递变化的数据
2.注意: 组件内部不要修改props数据
2.3.4. 编码操作
1.内部读取某个属性值

2.对props中的属性值进行类型限制和必要性限制
3.扩展属性: 将对象的所有属性通过props传递

4.默认属性值:

5.组件类的构造函数

2.4. 组件三大核心属性3: refs与事件处理

2.4.1. 效果
需求: 自定义组件, 功能说明如下:

  1. 点击按钮, 提示第一个输入框中的值
  2. 当第2个输入框失去焦点时, 提示这个输入框中的值
    效果如下:

2.4.2. 理解
组件内的标签可以定义ref属性来标识自己
2.4.3. 编码
1.字符串形式的ref

2.回调形式的ref

3.createRef创建ref容器·

2.4.4. 事件处理
1.通过onXxx属性指定事件处理函数(注意大小写)
1)React使用的是自定义(合成)事件, 而不是使用的原生DOM事件
2)React中的事件是通过事件委托方式处理的(委托给组件最外层的元素)
2.通过event.target得到发生事件的DOM元素对象
2.5. 收集表单数据
2.5.1. 效果
需求: 定义一个包含表单的组件
输入用户名密码后, 点击登录提示输入信息

2.5.2. 理解
包含表单的组件分类
1.受控组件
非受控组件
2.6. 组件的生命周期
2.6.1. 效果
需求:定义组件实现以下功能:

  1. 让指定的文本做显示 / 隐藏的渐变动画
  2. 从完全可见,到彻底消失,耗时2S
  3. 点击“不活了”按钮从界面中卸载组件

2.6.2. 理解
1.组件从创建到死亡它会经历一些特定的阶段。
2.React组件中包含一系列勾子函数(生命周期回调函数), 会在特定的时刻调用。
3.我们在定义组件时,会在特定的生命周期回调函数中,做特定的工作。
2.6.3. 生命周期流程图(旧)
生命周期的三个阶段(旧)
1. 初始化阶段: 由ReactDOM.render()触发—初次渲染
1.constructor()
2.componentWillMount()
3.render()
4.componentDidMount()
2. 更新阶段: 由组件内部this.setSate()或父组件重新render触发
1.shouldComponentUpdate()
2.componentWillUpdate()
3.render()
4.componentDidUpdate()
3. 卸载组件: 由ReactDOM.unmountComponentAtNode()触发
1.componentWillUnmount()
2.6.4. 生命周期流程图(新)

生命周期的三个阶段(新)

  1. 初始化阶段: 由ReactDOM.render()触发—初次渲染
    1.constructor()
    2.getDerivedStateFromProps
    3.render()
    4.componentDidMount()
    2. 更新阶段: 由组件内部this.setSate()或父组件重新render触发
    1.getDerivedStateFromProps
    2.shouldComponentUpdate()
    3.render()
    4.getSnapshotBeforeUpdate
    5.componentDidUpdate()
    3. 卸载组件: 由ReactDOM.unmountComponentAtNode()触发
    1.componentWillUnmount()
    2.6.5. 重要的勾子
    1.render:初始化渲染或更新渲染调用
    2.componentDidMount:开启监听, 发送ajax请求
    3.componentWillUnmount:做一些收尾工作, 如: 清理定时器
    2.6.6. 即将废弃的勾子
    1.componentWillMount
    2.componentWillReceiveProps
    3.componentWillUpdate
    现在使用会出现警告,下一个大版本需要加上UNSAFE_前缀才能使用,以后可能会被彻底废弃,不建议使用。
    2.7. 虚拟DOM与DOM Diffing算法
    2.7.1. 效果
    2.7.2. 基本原理图
    第5章:React路由
    5.1. 相关理解
    5.1.1. SPA的理解
    1.单页Web应用(single page web application,SPA)。
    2.整个应用只有一个完整的页面。
    3.点击页面中的链接不会刷新页面,只会做页面的局部更新。
    4.数据都需要通过ajax请求获取, 并在前端异步展现。
    5.1.2. 路由的理解
    1.什么是路由?
    1.一个路由就是一个映射关系(key:value)
    2.key为路径, value可能是function或component
    2.路由分类
    1.后端路由:
    1)理解: value是function, 用来处理客户端提交的请求。
    2)注册路由: router.get(path, function(req, res))
    3)工作过程:当node接收到一个请求时, 根据请求路径找到匹配的路由, 调用路由中的函数来处理请求, 返回响应数据
    2.前端路由:
    1)浏览器端路由,value是component,用于展示页面内容。
    2)注册路由:
    3)工作过程:当浏览器的path变为/test时, 当前路由组件就会变为Test组件
    5.1.3. react-router-dom的理解
    1.react的一个插件库。
    2.专门用来实现一个SPA应用。
    3.基于react的项目基本都会用到此库。
    5.2. react-router-dom相关API
    5.2.1. 内置组件
    1.
    2.
    3.
    4.
    5.
    6.
    7.
    5.2.2. 其它
    1.history对象
    2.match对象
    3.withRouter函数
    5.3. 基本路由使用
    5.3.1. 效果

5.3.2. 准备
1.下载react-router-dom: npm install --save react-router-dom
2.引入bootstrap.css:
5.4. 嵌套路由使用
效果

5.5. 向路由组件传递参数数据
第7章:redux
7.1. redux理解
7.1.1. 学习文档
1.英文文档: https://redux.js.org/
2.中文文档: http://www.redux.org.cn/
3.Github: https://github.com/reactjs/redux
7.1.2. redux是什么
1.redux是一个专门用于做状态管理的JS库(不是react插件库)。
2.它可以用在react, angular, vue等项目中, 但基本与react配合使用。
3.作用: 集中式管理react应用中多个组件共享的状态。
7.1.3. 什么情况下需要使用redux
1.某个组件的状态,需要让其他组件可以随时拿到(共享)。
2.一个组件需要改变另一个组件的状态(通信)。
3.总体原则:能不用就不用, 如果不用比较吃力才考虑使用。
7.1.4. redux工作流程
7.2. redux的三个核心概念
7.2.1. action
1.动作的对象
2.包含2个属性
type:标识属性, 值为字符串, 唯一, 必要属性
data:数据属性, 值类型任意, 可选属性
3.例子:{ type: ‘ADD_STUDENT’,data:{name: ‘tom’,age:18} }
7.2.2. reducer
1.用于初始化状态、加工状态。
2.加工时,根据旧的state和action, 产生新的state的纯函数。
7.2.3. store
1.将state、action、reducer联系在一起的对象
2.如何得到此对象?
1)import {createStore} from ‘redux’
2)import reducer from ‘./reducers’
3)const store = createStore(reducer)
3.此对象的功能?
1)getState(): 得到state
2)dispatch(action): 分发action, 触发reducer调用, 产生新的state
3)subscribe(listener): 注册监听, 当产生了新的state时, 自动调用
7.3. redux的核心API
7.3.1. createstore()
作用:创建包含指定reducer的store对象
7.3.2. store对象
1.作用: redux库最核心的管理对象
2.它内部维护着:
1)state
2)reducer
3.核心方法:
1)getState()
2)dispatch(action)
3)subscribe(listener)
4.具体编码:
1)store.getState()
2)store.dispatch({type:‘INCREMENT’, number})
3)store.subscribe(render)
7.3.3. applyMiddleware()
作用:应用上基于redux的中间件(插件库)
7.3.4. combineReducers()
作用:合并多个reducer函数
7.4. 使用redux编写应用
效果

7.5. redux异步编程
7.5.1理解:
1.redux默认是不能进行异步处理的,
2.某些时候应用中需要在redux中执行异步任务(ajax, 定时器)
7.5.2. 使用异步中间件
npm install --save redux-thunk
7.6. react-redux
7.6.1. 理解
1.一个react插件库
2.专门用来简化react应用中使用redux
7.6.2. react-Redux将所有组件分成两大类
1.UI组件
1)只负责 UI 的呈现,不带有任何业务逻辑
2)通过props接收数据(一般数据和函数)
3)不使用任何 Redux 的 API
4)一般保存在components文件夹下
2.容器组件
1)负责管理数据和业务逻辑,不负责UI的呈现
2)使用 Redux 的 API
3)一般保存在containers文件夹下
7.6.3. 相关API
1.Provider:让所有组件都可以得到state数据

2.connect:用于包装 UI 组件生成容器组件

3.mapStateToprops:将外部的数据(即state对象)转换为UI组件的标签属性

4.mapDispatchToProps:将分发action的函数转换为UI组件的标签属性

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习编程?其实不难,不过在学习编程之前你得先了解你的目的是什么?这个很重要,因为目的决定你的发展方向、决定你的发展速度。
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面设计类、前端与移动、开发与测试、营销推广类、数据运营类、运营维护类、游戏相关类等,根据不同的分类下面有细分了不同的岗位。
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生学习Java开发,但要结合自身的情况,先了解自己适不适合去学习Java,不要盲目的选择不适合自己的Java培训班进行学习。只要肯下功夫钻研,多看、多想、多练
Can’t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock问题 1.进入mysql路径
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 sqlplus / as sysdba 2.普通用户登录
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服务器有时候会断掉,所以写个shell脚本每五分钟去判断是否连接,于是就有下面的shell脚本。
BETWEEN 操作符选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期。
假如你已经使用过苹果开发者中心上架app,你肯定知道在苹果开发者中心的web界面,无法直接提交ipa文件,而是需要使用第三方工具,将ipa文件上传到构建版本,开...
下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。**提示:**如果列名称包含空格,要求使用双引号或方括号:
在使用H5混合开发的app打包后,需要将ipa文件上传到appstore进行发布,就需要去苹果开发者中心进行发布。​
+----+--------------+---------------------------+-------+---------+
数组的声明并不是声明一个个单独的变量,比如 number0、number1、...、number99,而是声明一个数组变量,比如 numbers,然后使用 nu...
第一步:到appuploader官网下载辅助工具和iCloud驱动,使用前面创建的AppID登录。
如需删除表中的列,请使用下面的语法(请注意,某些数据库系统不允许这种在数据库表中删除列的方式):
前不久在制作win11pe,制作了一版,1.26GB,太大了,不满意,想再裁剪下,发现这次dism mount正常,commit或discard巨慢,以前都很快...
赛门铁克各个版本概览:https://knowledge.broadcom.com/external/article?legacyId=tech163829
实测Python 3.6.6用pip 21.3.1,再高就报错了,Python 3.10.7用pip 22.3.1是可以的
Broadcom Corporation (博通公司,股票代号AVGO)是全球领先的有线和无线通信半导体公司。其产品实现向家庭、 办公室和移动环境以及在这些环境...
发现个问题,server2016上安装了c4d这些版本,低版本的正常显示窗格,但红色圈出的高版本c4d打开后不显示窗格,
TAT:https://cloud.tencent.com/document/product/1340