Skip to content

GrayJunZi/learn-react-ultimate

Repository files navigation

Learn React


Udemy - The Ultimate React Course 2024: React,Redux & More

一、基础(Foundamentals)

1. React 初探

  • 为什么使用 React?
  • 什么是 React?
  • React 与原生 js 对比?
  • 设置 React 开发环境?

单独使用普通的 JavaScript 构建一个复杂的前端,需要大量的直接 DOM 遍历和操作,甚至会有文本和 CSS 样式的操作。在一个复杂的应用程序中,这将会是一个噩梦,因为我们的代码会随着时间的推移变得非常复杂和难以理解。

在典型的 JavaScript 应用程序中,简单的文本和数字等状态通常被简单地存储在 DOM 中。

前端框架存在的根本原因是保持用户界面和数据同步真的很难,所以基本上像 React 或 Vue 这类的框架把数据和用户界面同步的艰苦工作从开发身上带走,他们解决了非常难的问题。这样开发人员就可以专注于数据和构建用户界面了。

什么是 React?

React 是一个用于构建用户界面的 JavaScript 库。

React 是由 FACEBOOK 创建的极受欢迎的、声明性的、基于组件的、状态驱动的用于构建用户界面的 JavaScript 库。

  • Based on components - 组件是 React 中用户界面的构建块(building blocks)。

  • Declarative - 为了描述每个组件的样子以及它是如何工作的,使用了名为jsx的特殊声明语法。用于告诉 React 组件是什么样的,整个界面基于当前状态。React 是一种抽象方式,从而不需要直接操作 DOM。jsx结合了 html、css、js 的部分内容、也允许我们引用其他 React 组件。

  • State-driven - React 的主要目标是保持 UI 和数据的同步。我们将数据称作状态(state),React 将使用 jsx 编写的组件呈现在用户界面上,每当状态改变时,React 将自动重新呈现用户界面以显示最新状态。React 通过重新渲染来对状态做出反应。

  • JavaScript Library - React 实际上只是一个库,尽管我们一直称作框架,因为 React 本身实际上只是所谓的视图层,所以如果我们想构建一个完整的真实世界应用程序,我们需要选择多个外部库来添加到我们的项目中,例如路由或数据获取。

  • Extremely popular - React 是迄今为止使用最多的框架,很大的原因是许多大公司很久以前就采用的 React,所以越来越多的公司都在追随他们的脚步。

  • 根据 Web 界面上的组件的当前状态将其渲染(rendering)到用户界面(UI)。

  • React 通过在状态变化时重新呈现 (反应),使 UI 与状态保持同步。

设置开发环境

安装 VSCode 插件

  • ESLint
  • Prettier - Code formatter

创建 React 项目的工具

create-react-app 是 React 应用程序的完整初学者工具包,使开发人员很容易搭建新项目的脚手架。好处是常见的开发工具已经预先配置好了,所以使用 create-react-app 创建的应用程序会自动附带开发服务器。缺点是该项目使用 webpack 构建 技术已经过时了。

Vite 是一个现代的构建工具,也包含了初学者模板,用于设置权限的 React 应用程序,然而使用 Vite 创建的应用程序中,不得不手动设置许多重要的开发工具。

创建 React 项目

create-react-app 是一个命令行工具(cli),使用命令 npx create-react-app pizza-menu 构建项目。

2. JavaScript 复习

  • 解构(对象属性解构、数组解构)
  • 展开操作符(...arrays)
  • 字符串模板(`${}``)
  • 三元表达式(?:)
  • 箭头函数( () => 1 )
  • 短路与逻辑操作符 ( true && "result" )
  • 可选链接运算符(?.)
  • 数组方法(map、filter、reduce、sort)
  • 异步处理(promise、async await)

3. 使用 Components、Props 和 JSX

我们将探索构建 React 应用程序的三个核心概念 Components、Props 和 JSX。

  • 了解组件是如何构建 React 应用程序的,以及如何使用强大的 jsx 语法创建和重用它们。
  • 使用 props 在组件之间共享数据并了解如何渲染列表。

组件作为构建块

组件是 React 中最基本的概念,因为 React 应用程序实际上完全由组件组成。

JSX

JSX 是声明式语法,根据组件的数据和逻辑描述外观的组件以及它们是如何工作的。

JSX 是 JavaScript 的扩展,允许我们嵌入一些 JavaScript、CSS 和 React 组件的片段到 HTML 中。

React 应用程序通过 Babel 工具自动将 jsx 代码转换为 JavaScript 代码,其中每个 jsx 元素都被转换为一个 React.createElement函数调用。

关注点分离(Separation of Concerns)

传统的关注点分离是将 HTML、JavaScript、CSS 分离到不同的文件中。而 React 采用的则是一个全新的范式,每个组件只关注 UI 中的一小块。

Props

  • props 用于将数据从父组件传递到子组件(沿着组件树)。
  • 配置和自定义组件的基本工具。
  • 通过props,父组件控制子组件的外观和工作方式。
  • 任何东西都可以作为props传递:单值数组、对象、函数,甚至其他组件。

props 是只读的,不可变的,这是 React 严格规则之一。如果需要改变,需要使用state

React 是单向数据流(one-way data flow)

  • 使应用程序更可预测,更易于理解。
  • 使应用程序更容易调试,因为我们对数据有更多的控制权。
  • 更好的性能(performant)。

Angular 是双向数据流。

JSX 规则

  • JSX 的工作原理基本上类似于 HTML,但我们可以通过使用(用于文本或属性)进入“JavaScript 模式”。

  • 我们可以把 JavaScript 表达式放在{}里面。例如:引用变量、创建数组或对象、[].map()、三元运算符

  • 不允许使用语句 (if/else,for,switch)

  • JSX 生成一个 JavaScript 表达式。

  • JSX 根节点只能有一个元素。

  • className 实际上就是 html 的 class

  • htmlFor 实际上就是 html 的 for

  • 每个标签都需要结束,例如 <img/><br />

  • 所有的事件处理器和其他属性都遵循小驼峰(camelCased),例如 onClickonMouseOver

  • css内联样式使用 {{style}}

  • css属性也是小驼峰。

  • 注释需要使用{}包起来,因为它们是JS。

4. 状态、事件和表单: 交互式组件

构建Steps组件

使用命令 npx create-react-app steps 创建项目。

事件处理

export default function App() {

  function handlePreviuos() {
    console.log("clicking previous...");
  }

  return (
        ...

        <button
          style={{ backgroundColor: "#7950f2", color: "#fff" }}
          onClick={handlePreviuos}
        >
          Previous
        </button>
        
        ...
  );
}

什么是状态(State)?

  • 组件在一段时间内可以保存的数据,这些数据对于在应用的整个生命周期中需要记住的信息来说是必要的。
  • 组件状态:单个局部组件变量。
  • 更新组件状态触发器React以重新呈现组件。

状态机制(Mechanics)

我们不直接操作DOM,我们通过 useState 更新状态,然后react重新渲染组件。

这也是被称为React的原因,通过重新渲染用户界面来对状态变更做出反应。

状态实用指南(Practical Guideline)

每个组件都有并且管理自己的状态,无论渲染同一个组件多少次。

  • 对于组件应该随时间跟踪(“记住”)的任何数据,使用状态变量。这是在某个时间点会改变的数据。在原生JS中,这是一个let变量,或者是 [] 或者是 {}。
  • 每当您希望组件中的某个东西是动态的,就创建一段与该“东西”相关的状态,并在该东西”应该改变时更新状态(也就是“动态的”)。
  • 如果要更改组件的外观或显示的数据,请更新其状态。这通常发生在事件处理函数中。
  • 构建组件时,请将其视图想象为随时间变化的状态的反映。
  • 对于不应该触发组件重新呈现的数据,不要使用状态。用常规变量代替。这是初学者常犯的错。

State与Props对比

  • State
    • 组件内容数据。
    • 组件内存。
    • 可以由组件自身进行更新。
    • 更新数据会造成组件重新渲染。
    • 使用状态会使组件更具有交互性。
  • Props
    • 外部数据,由父组件所拥有。
    • 类似于函数参数。
    • 只读。
    • 接收新Props会导致组件重新渲染。通常当父级的状态已被更新时。
    • 由父级用于配置子组件。

二、中级(Intermediate)

三、高级(Advanced React+Redux)

四、专业(Professional React Development)