React 学习笔记

这篇具有很好参考价值的文章主要介绍了React 学习笔记。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

React

React.js是一个开源的JavaScript库,由Facebook于2013年开发,用于构建用户界面或UI组件。它主要用于构建单页应用程序或SPA,并且可以在Web和移动应用程序中使用。React.js使用虚拟DOM来提高性能,并使用组件化的方式来实现代码的重用和组织。

特点

  1. 高效性能:React.js使用虚拟DOM来减少直接DOM操作,从而提高性能。
  2. 组件化:React.js使用组件来构建应用程序,使得代码更易于维护、重用和组织。
  3. 声明式编程:React.js使用声明式编程方式来描述界面和状态的变化,使得代码更易于理解和预测。
  4. 跨平台:React.js可以用于构建Web和移动应用程序,并且具有跨平台的兼容性。
  5. 开源:React.js是开源的JavaScript库,具有广泛的社区支持和资源。

一、创建React项目

  1. create-react-app创建
    在终端中输入以下命令来创建一个新的React项目:

    npx create-react-app my-app
    

    其中,"my-app"是要创建的项目的名称。

  2. Vite
    使用 NPM:

    npm create vite@latest
    

    使用 Yarn:

    yarn create vite
    

    使用 PNPM:

    pnpm create vite
    

    然后按照提示操作即可!

  3. 目录结构

    my-app
    ├─ .eslintrc.cjs
    ├─ .gitignore
    ├─ index.html
    ├─ package.json
    ├─ public
    │  └─ vite.svg
    ├─ README.md
    ├─ src
    │  ├─ App.css
    │  ├─ App.jsx
    │  ├─ assets
    │  │  └─ react.svg
    │  ├─ index.css
    │  └─ main.jsx
    └─ vite.config.js
    
    

二、React组件创建和嵌套组件

React 应用程序是由组件组成的。一个组件是 UI(用户界面)的一部分,它拥有自己的逻辑和外观。组件可以小到一个按钮,也可以大到整个页面。

React 组件是返回标签的 JavaScript 函数

React组件的类型

  1. 函数组件和类组件:这是根据定义组件的方法来划分的。

    • 函数组件使用函数来定义组件,只返回React元素。
    • 类组件使用ES6 class来定义组件,可以包含更多的功能,比如有状态、生命周期方法等。
  2. 无状态组件和有状态组件:这是根据组件内部是否维护state来划分的。

    • 无状态组件内部不使用state,只根据外部组件传入的props返回待渲染的React元素。
    • 有状态组件则维护了自己的state,并能主动触发更新。
  3. 展示型组件和容器型组件:这是根据组件的功能来划分的。

    • 展示型组件专门写结构,里面没有逻辑,逻辑都是从容器组件传过来的,俗称傻瓜组件。
    • 容器型组件专门写逻辑,里面没有UI结构,俗称聪明组件。
函数组件
// button.jsx
function MyButton() {
  return (
    <button>button</button>
  );
}

export default MyButton;
类组件
// button.jsx
// import React from 'react';
import React, { Component } from 'react';

// class MyButton extends React.Component {
class MyButton extends Component {
    constructor() {}
    render() {
        return (
            <button>button</button>
        );
    }
}

export default MyButton;
嵌套组件
import MyButton from './button';
function MyComponent() {
  return (  
    <div>  
      <p>这是一个按钮</p>  
      <MyButton /> 
    </div>  
  );  
}

上面所使用的标签语法被称为 JSX。它是可选的,但大多数 React 项目会使用 JSX,主要是它很方便。

JSX 比 HTML 更加严格。你必须闭合标签,如<br />。你的组件也不能返回多个 JSX 标签。你必须将它们包裹到一个共享的父级中,比如 <div>...</div> 或使用空的 <>...</> 包裹。

添加样式

在 React 中,你可以使用 className 来指定一个 CSS 的 class。它与 HTML 的 class 属性的工作方式相同:

<img className="avatar" />

然后,你可以在一个单独的 CSS 文件中为它编写 CSS 规则:

/* In your CSS */
.avatar {
  border-radius: 50%;
}

显示数据

JSX 会让你把标签放到 JavaScript 中。而大括号会让你 “回到” JavaScript 中,这样你就可以从你的代码中嵌入一些变量并展示给用户。例如:

function MyComponent(props) {  
  const count = 0; 
  
  return (  
    <div>  
      <p>Count: {count}</p>  
      <button>Button</button>  
    </div>  
  );  
}

你还可以将 JSX 属性 “转义到 JavaScript”,但你必须使用大括号 而非 引号。例如,className=“avatar” 是将 “avatar” 字符串传递给 className,作为 CSS 的 class。但 src={user.imageUrl} 会读取 JavaScript 的 user.imageUrl 变量,然后将该值作为 src 属性传递:

const user = {
  name: 'Hedy Lamarr',
  imageUrl: 'https://i.imgur.com/yXOvdOSs.jpg',
  imageSize: 90,
};
export default function Profile() {
  return (
    <>
      <h1>{user.name}</h1>
      <img
        className="avatar"
        src={user.imageUrl}
        alt={'Photo of ' + user.name}
        style={{
          width: user.imageSize,
          height: user.imageSize
        }}
      />
    </>
  );
}

在上面示例中,style={{}} 并不是一个特殊的语法,而是 style={ } JSX 大括号内的一个普通 {} 对象。当你的样式依赖于 JavaScript 变量时,你可以使用 style 属性。

条件渲染

React 没有特殊的语法来编写条件语句,因此使用的就是普通的 JavaScript 代码。例如,if 语句、&&? : 运算符来选择性地渲染 JSX:

let content;
if (isLoggedIn) {
  content = <AdminPanel />;
} else {
  content = <LoginForm />;
}
return (
  <div>
    {content}

    {isLoggedIn ? (<AdminPanel />) : (<LoginForm />)}

    {/* 切勿将数字放在 && 左侧 */}
    {isLoggedIn && <AdminPanel />}
  </div>
);

切勿将数字放在 && 左侧.

JavaScript 会自动将左侧的值转换成布尔类型以判断条件成立与否。然而,如果左侧是 0,整个表达式将变成左侧的值(0),React 此时则会渲染 0 而不是不进行渲染。

渲染列表

依赖 JavaScript 的特性,例如 for 循环 和 array 的 map() 函数 来渲染组件列表。

在你的组件中,使用 map() 函数将这个数组转换为 <li> 标签构成的列表:

function CustomUl() {
    const products = [
        { title: 'Cabbage', id: 1 },
        { title: 'Garlic', id: 2 },
        { title: 'Apple', id: 3 },
    ];

    const listItems = products.map(product =>
        <li key={product.id}>
            {product.title}
        </li>
    );

    return (
        <ul>{listItems}</ul>
    );
}

直接放在 map() 方法里的 JSX 元素一般都需要指定 key 值!

响应事件

使用 React 可以在 JSX 中添加 事件处理函数。其中事件处理函数为自定义函数,它将在响应交互(如点击、悬停、表单输入框获得焦点等)时触发。

如需添加一个事件处理函数,需要先定义一个函数,然后 将其作为 prop 传入 合适的 JSX 标签。

function MyButton() {
  function handleClick() {
    alert('You clicked me!');
  }

  return (
    <>
        <button onClick={handleClick}>
            Click me
        </button>
        <button onClick={() => {
            alert('You clicked me!')
        }}>
            Click me
        </button>
    </>
  );
}

注意,onClick={handleClick} 的结尾没有小括号!不要 调用 事件处理函数:你只需 把函数传递给事件 即可。当用户点击按钮时 React 会调用你传递的事件处理函数。

更新界面

通常你会希望你的组件 “记住” 一些信息并展示出来,比如一个按钮被点击的次数。要做到这一点,你需要在你的组件中添加 state。

首先,从 React 引入 useState

import { useState } from 'react';

现在可以在组件中声明一个 state 变量:

function MyButton() {
  const [count, setCount] = useState(0);
  // ...

将从 useState 中获得两样东西:当前的 state(count),以及用于更新它的函数(setCount)。可以给它们起任何名字,但按照惯例会像 [something, setSomething] 这样为它们命名。

这里的 [] 语法称为数组解构,它允许你从数组中读取值。 useState 返回的数组总是正好有两项。

第一次显示按钮时,count 的值为 0,因为你把 0 传给了 useState()。当你想改变 state 时,调用 setCount() 并将新的值传递给它。点击该按钮计数器将递增:

function MyButton() {
  const [count, setCount] = useState(0);

  function handleClick() {
    setCount(count + 1);
  }

  return (
    <button onClick={handleClick}>
      Clicked {count} times
    </button>
  );
}

React 将再次调用你的组件函数。第一次 count 变成 1。接着点击会变成 2。继续点击会逐步递增。

如果你多次渲染同一个组件,每个组件都会拥有自己的 state。

注意,每个按钮会 “记住” 自己的 count,而不影响其他按钮。

更新 React state 中的对象
import { useState } from 'react';
export default function MovingDot() {
  const [userInfo, setUserInfo] = useState({
    age: 14,
    height: 150
  });
  const addAge = () => {
    // userInfo.age += 1; 数据改变了,但是不会触发视图更新
    setUserInfo({
        ...userInfo,
        age: age + 1,
    })
  }
  const addHeight = () => {
    // userInfo.height += 1; 数据改变了,但是不会触发视图更新
    setUserInfo({
        ...userInfo,
        height: height + 1,
    })
  }
  return (
    <div>
        <p>
            <span>年龄</span>: {userInfo.age}
        </p>
        <p>
            <span>身高</span>: {userInfo.height}
        </p>
        <button onClick={addAge}>年龄 + 1</button>
        <button onClick={addHeight}>身高 + 1</button>
    </div>
  );
}
更新 React state 中的数组
避免使用 (会改变原始数组) 推荐使用 (会返回一个新数组)
添加元素 pushunshift concat[...arr] 展开语法
删除元素 popshiftsplice filterslice
替换元素 splicearr[i] = ... 赋值 map
排序 reversesort 先将数组复制一份
const [artists, setArtists] = useState([]);

setArtists(
    [...artists, '张杰', '周杰伦', '李荣浩']
)

使用 Hook

use 开头的函数被称为 Hook。useState 是 React 提供的一个内置 Hook。你可以在 React API 参考 中找到其他内置的 Hook。你也可以通过组合现有的 Hook 来编写属于你自己的 Hook。

Hook 比普通函数更为严格。你只能在你的组件(或其他 Hook)的 顶层 调用 Hook。如果你想在一个条件或循环中使用 useState,请提取一个新的组件并在组件内部使用它。

将 Props 传递给组件

向组件传递 props
export default function Profile() {
  return (
    <Avatar
        person={{ name: 'Lin Lanying', imageId: '1bX5QH6' }}
        size={100}
    />
  );
}
在子组件中读取 props
// 给 prop 指定一个默认值 
function Avatar({ person, size = 100 }) {
  // ...
}

这种语法被称为 “解构”,等价于于从函数参数中读取属性:

function Avatar(props) {
  let person = props.person;
  let size = props.size;
  // ...
}
组件共享数据
import { useState } from 'react';

export default function MyApp() {
  const [count, setCount] = useState(0);

  function handleClick() {
    setCount(count + 1);
  }

  return (
    <div>
      <h1>Counters that update together</h1>
      <MyButton count={count} onClick={handleClick} />
      <MyButton count={count} onClick={handleClick} />
    </div>
  );
}

function MyButton({ count, onClick }) {
  return (
    <button onClick={onClick}>
      Clicked {count} times
    </button>
  );
}
使用 JSX 展开语法传递 props

有时候,传递 props 会变得非常重复:

function Profile({ person, size, isSepia, thickBorder }) {
  return (
    <div className="card">
      <Avatar
        person={person}
        size={size}
        isSepia={isSepia}
        thickBorder={thickBorder}
      />
    </div>
  );
}

重复代码没有错(它可以更清晰)。但有时你可能会重视简洁。一些组件将它们所有的 props 转发给子组件,正如 Profile 转给 Avatar 那样。因为这些组件不直接使用他们本身的任何 props,所以使用更简洁的“展开”语法是有意义的:

function Profile(props) {
  return (
    <div className="card">
      <Avatar {...props} />
    </div>
  );
}

将 JSX 作为子组件传递 等价于 slot 概念

将内容嵌套在 JSX 标签中时,父组件将在名为 children 的 prop 中接收到该内容。文章来源地址https://www.toymoban.com/news/detail-739882.html

function Card({ children }) {
  return (
    <div className="card">
      {children}
    </div>
  );
}

export default function Profile() {
  return (
    <Card>
      <Avatar
        size={100}
        person={{ 
          name: 'Katsuko Saruhashi',
          imageId: 'YfeOqp2'
        }}
      />
    </Card>
  );
}

到了这里,关于React 学习笔记的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 前端框架学习-React(一)

    React 应用程序是由 组件 组成的。 react 程序是用的jsx语法,使用这种语法的代码需要由babel进行解析,解析成js代码。 jsx语法: 只能返回一个根元素 所有的标签都必须闭合(自闭和或使用一对标签的方式闭合) 使用驼峰式命名法给大部分属性命名如:className 大写字母开头的

    2024年02月12日
    浏览(30)
  • 如何使用前端框架(React、Angular、Vue.js等)?该如何选择?

    聚沙成塔·每天进步一点点 前端入门之旅:探索Web开发的奇妙世界 欢迎来到前端入门之旅!感兴趣的可以订阅本专栏哦!这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发者,这里都将为你提供一个系统而

    2024年02月07日
    浏览(47)
  • 简介:在这篇教程中,我们将使用React.js框架创建一个简单的聊天机器人的前端界面,并利用Dialogflo

    作者:禅与计算机程序设计艺术 介绍及动机 聊天机器人(Chatbot)一直是互联网领域中的热门话题。而很多聊天机器人的功能都依赖于人工智能(AI)技术。越来越多的企业希望拥有自己的聊天机器人系统,从而提升自己的竞争力。为此,业界也出现了很多基于开源技术或云

    2024年02月06日
    浏览(42)
  • React学习笔记(番外一)——video.js视频播放组件的入门及排坑经历

    很久没有静下心写博客了。近段时间接到一个任务,前端页面要加上视频播放功能。实现加排坑前后花了三天时间(别问我问什么这么久😂),觉得还是有必要记录一下的。 这一部分有必要写在最前面,避免你看了一长串安装、引入、代码,然后发现自己想要播放的视频格

    2024年02月02日
    浏览(38)
  • React框架:TypeScript支持的JavaScript库

    React 框架是一个功能强大的 JavaScript 库,让用户可以轻松地构建高度动态的用户界面。它借助虚拟 DOM 的思想实现高效的性能,并具有易于使用和灵活的编程接口。随着越来越多的人开始使用 React ,在不断的发展和变化中, React 框架现在加入了 TypeScript 的支持,使其成为一个

    2024年02月11日
    浏览(52)
  • 前端框架 Nextjs React 部署

    目录 一、node环境部署 二、静态导出 补充:路由问题 Nextjs打包还是非常方便的,就是网上资料不太全,导致踩了一些坑,下面是我亲自实践的两种打包方式。 一、node环境部署 这种方式最简单,也比较不容易出错,但部署时服务器需安装有node环境,速度没话说,杠杠的! 构

    2024年02月12日
    浏览(37)
  • Vue 和 React 前端框架的比较

    本文研究了流行的前端框架 Vue 和 React 之间的区别。通过对它们的学习曲线、视图层处理方式、组件化开发、响应式数据处理方式和生态系统及社区支持进行比较分析,得出了它们在不同方面的优劣和特点。该研究对于开发者在选择合适的前端框架时提供参考。 Vue 是一款由

    2024年02月13日
    浏览(50)
  • React与Vue:前端框架的比较

    在前端开发领域,React和Vue是两个备受瞩目的框架。它们都提供了构建用户界面的强大工具,但它们在实现方式、性能和设计理念上存在一些关键差异。本文将深入探讨这两个框架之间的主要区别。 首先,让我们从数据流的角度来看。在Vue中,数据流是双向的,这意味着组件

    2024年01月20日
    浏览(39)
  • 前端(七)——React框架的定位与应用场景解析

    😊博主:小猫娃来啦 😊文章核心: React框架的定位与应用场景解析 什么是react? React 是一个由 Facebook 开发的开源 JavaScript库,用于构建用户界面。 于2013年首次发布,并迅速成为前端开发中最受欢迎的框架之一。 在 React 诞生之前,前端开发面临着许多挑战,包括复杂的D

    2024年02月17日
    浏览(30)
  • React与Vue性能对比:两大前端框架的性能

    React和Vue是当今最流行的两个前端框架,它们在性能方面都有着出色的表现。 React的加载速度: 初次加载:由于React使用了虚拟DOM(Virtual DOM)技术,它可以通过比较虚拟DOM树与实际DOM树的差异来进行高效的重绘。这使得React在初次加载时相对较快,因为它只会更新需要修改的

    2024年02月03日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包