React全家桶(技术栈)

本文详细介绍了React技术栈,从React的基本概念、特点到实际使用,包括虚拟DOM、JSX语法、组件化编程、状态管理和props、事件处理、生命周期、模块化与组件化。此外,还涉及了React应用的创建、路由、Ajax请求、流行的UI组件库如Material-UI和Ant Design,以及Redux的状态管理。最后讲解了Redux的核心概念和使用,包括Action、Reducer、Store以及如何处理异步操作。
摘要由CSDN通过智能技术生成

第1章:React入门
1.1. React简介
1.1.1. 官网

  1. 英文官网: https://reactjs.org/
  2. 中文官网: https://react.docschina.org/
    1.1.2. 介绍描述
  3. 用于动态构建用户界面的 JavaScript 库(只关注于视图)
  4. 由Facebook开源
    1.1.3. React的特点
  5. 声明式编码
  6. 组件化编码
  7. React Native 编写原生应用
  8. 高效(优秀的Diffing算法)
    1.1.4. React高效的原因
  9. 使用虚拟(virtual)DOM, 不总是直接操作页面真实DOM。
  10. DOM Diffing算法, 最小化页面重绘。
    1.2. React的基本使用
    1.2.1. 效果

1.2.2. 相关js库

  1. react.js:React核心库。

  2. react-dom.js:提供操作DOM的react扩展库。

  3. babel.min.js:解析JSX语法代码转为JS代码的库。
    1.2.3. 创建虚拟DOM的两种方式

  4. 纯JS方式(一般不用)

  5. JSX方式
    1.2.4. 虚拟DOM与真实DOM

  6. React提供了一些API来创建一种 “特别” 的一般js对象
     const VDOM = React.createElement(‘xx’,{id:‘xx’},‘xx’)
     上面创建的就是一个简单的虚拟DOM对象

  7. 虚拟DOM对象最终都会被React转换为真实的DOM

  8. 我们编码时基本只需要操作react的虚拟DOM相关数据, react会转换为真实DOM变化而更新界。
    1.3. React JSX
    1.3.1. 效果

1.3.2. JSX

  1. 全称: JavaScript XML
  2. react定义的一种类似于XML的JS扩展语法: JS + XML本质是React.createElement(component, props, …children)方法的语法糖
  3. 作用: 用来简化创建虚拟DOM
  1. 写法:var ele =

    Hello JSX!

  2. 注意1:它不是字符串, 也不是HTML/XML标签
  3. 注意2:它最终产生的就是一个JS对象
  1. 标签名任意: HTML标签或其它标签
  2. 标签属性任意: HTML标签属性或其它
  3. 基本语法规则
  1. 遇到 <开头的代码, 以标签的语法解析: html同名标签转换为html同名元素, 其它标签需要特别解析
  2. 遇到以 { 开头的代码,以JS语法解析: 标签中的js表达式必须用{ }包含
  1. babel.js的作用
  1. 浏览器不能直接解析JSX代码, 需要babel转译为纯JS的代码才能运行
  2. 只要用了JSX,都要加上type=“text/babel”, 声明需要babel来处理
    1.3.3. 渲染虚拟DOM(元素)
  1. 语法: ReactDOM.render(virtualDOM, containerDOM)
  2. 作用: 将虚拟DOM元素渲染到页面中的真实容器DOM中显示
  3. 参数说明
  1. 参数一: 纯js或jsx创建的虚拟dom对象
  2. 参数二: 用来包含虚拟DOM元素的真实dom元素对象(一般是一个div)
    1.3.4. JSX练习
    需求: 动态展示如下列表

1.4. 模块与组件、模块化与组件化的理解
1.4.1. 模块

  1. 理解:向外提供特定功能的js程序, 一般就是一个js文件
  2. 为什么要拆成模块:随着业务逻辑增加,代码越来越多且复杂。
  3. 作用:复用js, 简化js的编写, 提高js运行效率
    1.4.2. 组件
  4. 理解:用来实现局部功能效果的代码和资源的集合(html/css/js/image等等)
  5. 为什么要用组件: 一个界面的功能更复杂
  6. 作用:复用编码, 简化项目编码, 提高运行效率
    1.4.3. 模块化
    当应用的js都以模块来编写的, 这个应用就是一个模块化的应用
    1.4.4. 组件化
    当应用是以多组件的方式实现, 这个应用就是一个组件化的应用

第2章:React面向组件编程
2.1. 基本理解和使用
2.1.1. 使用React开发者工具调试

2.1.2. 效果
函数式组件:

类式组件:

2.1.3. 注意

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

2.2.2. 理解

  1. state是组件对象最重要的属性, 值是对象(可以包含多个key-value的组合)
  2. 组件被称为"状态机", 通过更新组件的state来更新对应的页面显示(重新渲染组件)
    2.2.3. 强烈注意
  3. 组件中rende
  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值