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)
相关推荐
憧憬成为web高手5 小时前
ACTF 12307复现
前端·bootstrap·html
wordbaby5 小时前
Axios 上传大文件崩溃:鸿蒙 RNOH 下 XHR 返回空响应头引发的"假失败"
前端·react native
wordbaby6 小时前
React Native 列表分页实战:下拉刷新与上拉加载的工程化方案
前端·react native
星栈独行6 小时前
我在 Rust 全栈项目里用 JWT 做无状态认证
开发语言·后端·rust·前端框架·开源·github·web
wordbaby6 小时前
脱离 Tab 栏的艺术:React Native 全屏子页面的导航架构实践
前端·react native·harmonyos
陈随易7 小时前
Redis 8.8发布,一定要更新
前端·后端·程序员
wordbaby7 小时前
React Native 新架构落地鸿蒙:跨三端政务级应用的工程实践与深度复盘
前端·react native·harmonyos
excel8 小时前
为什么我推荐使用 Termius:现代 SSH 工具的完整体验
前端·后端
ZC跨境爬虫8 小时前
模块化烹饪小程序开发日记 Day7:(菜谱详情接口开发与JSON数据读取全流程)
前端·javascript·css·ui·微信小程序·json
এ慕ོ冬℘゜8 小时前
JS 前端基础面试题
开发语言·前端·javascript