React第一章(基本介绍)

React入门

什么是react?

https://message163.github.io/react-docs/

React 是一个用于构建用户界面的 JavaScript 库。它由 Facebook(现Meta) 开发和维护,并在2013年开源。React 的设计初衷是帮助开发者构建复杂的用户界面,同时保持代码的可维护性和可扩展性。

react的特点

  1. 组件化:React 通过将 UI 分解为独立的、可重用的组件,使得代码更易于管理和维护。每个组件只关注于自身的逻辑和视图。

  2. 声明式编程:React 采用声明式的编程风格,开发者只需描述 UI 应该是什么样子的,而不需要手动操作 DOM。React 会根据数据的变化自动更新 UI。

原生js时代渲染数据

js 复制代码
const arr = [
    {
        name: '小明',
        age: 18
    },
    {
        name: '小红',
        age: 19
    }
]
const container = document.createElement('ul')
arr.forEach(item => {
    const span = document.createElement('li')
    span.textContent = item.name + item.age 
    container.append(span)
})
document.body.append(container)

框架阶段 不需要在手动操作dom

js 复制代码
const arr = [
    {
        name: '小明',
        age: 18
    },
    {
        name: '小红',
        age: 19
    }
]

const App  = () => {
    return (arr.map(v=>{
        return <div>{item.name} {item.age} </div>
    }))
}
  1. 虚拟 DOM:React 使用虚拟 DOM(Virtual DOM)来优化 UI 的更新过程。当数据发生变化时,React 会创建一个新的虚拟 DOM,然后将其与之前的虚拟 DOM 进行比较,找出最小的变化,并将这些变化应用到实际的 DOM 中,从而提高性能。

  2. 单向数据流:React 采用单向数据流(也称为单向数据绑定),这意味着数据在组件之间通过 props 进行传递,使得数据的流动更加清晰和可预测。

  3. 生态系统:React 有一个庞大且活跃的社区,提供了大量的第三方库和工具,如 React Router(用于路由管理)、Redux(用于状态管理)等,帮助开发者构建复杂的应用。

前置知识

你必须学会以下知识才能使用 React:

  • JavaScript(es6+)
  • HTML
  • CSS
  • TypeScript(基本使用) Typescript教程
  • Npm包管理器

React市场情况

npm官网统计(不包含镜像) 2024-9-4

  1. react 18.3.1 周下载量 22,538,510
  2. vue 3.4.31 周下载量 4,699,312
  3. Angular 18.1.0 周下载量 3,216,414
  4. jQuery 3.7.10 周下载量 10,210,940
  5. solid 1.8.18 周下载量 288,278

安装环境准备

  1. node.js
    下载地址:https://nodejs.org/en 建议安装18以上版本,或者使用nvm管理node版本
  2. vsocde编辑器(如果安装过了请略过|或者喜欢其他编辑器) https://code.visualstudio.com/
  3. vscode插件安装 可选 (Simple React Snippets)
相关推荐
DoraBigHead12 分钟前
this 的前世今生:谁在叫我,我听谁的
前端·javascript·面试
蓝婷儿1 小时前
每天一个前端小知识 Day 28 - Web Workers / 多线程模型在前端中的应用实践
前端
琹箐1 小时前
Ant ASpin自定义 indicator 报错
前端·javascript·typescript
小小小小小惠1 小时前
Responsetype blob会把接口接收的二进制文件转换成blob格式
前端·javascript
爱电摇的小码农1 小时前
【深度探究系列(5)】:前端开发打怪升级指南:从踩坑到封神的解决方案手册
前端·javascript·css·vue.js·node.js·html5·xss
kymjs张涛1 小时前
零一开源|前沿技术周报 #7
android·前端·ios
爱编程的喵1 小时前
React入门实战:从静态渲染到动态状态管理
前端·javascript
Tttian6222 小时前
npm init vue@latestnpm error code ETIMEDOUT
前端·vue.js·npm
患得患失9492 小时前
【前端】【组件库开发】【原理】【无框架开发】现代网页弹窗开发指南:从基础到优化
前端
AliciaIr2 小时前
深入React事件机制:解密“合成事件”与“事件委托”的底层奥秘
javascript·react.js