Marvel-Site Marvel-Site
首页
  • Java

    • Java基础
    • Java进阶
    • Java容器
    • Java并发编程
    • Java虚拟机
  • 计算机基础

    • 数据结构与算法
    • 计算机网络
    • 操作系统
    • Linux
  • 框架|中间件

    • Spring
    • MySQL
    • Redis
    • MQ
    • Zookeeper
    • Git
  • 架构

    • 分布式
    • 高并发
    • 高可用
    • 架构
  • 框架

    • React
    • 其他
  • 实用工具
  • 安装配置

    • Linux
    • Windows
    • Mac
  • 开发工具

    • IDEA
    • VsCode
  • 关于
  • 收藏
  • 草稿
  • 索引

    • 分类
    • 标签
    • 归档
GitHub (opens new window)

Marvel

吾必当乘此羽葆盖车
首页
  • Java

    • Java基础
    • Java进阶
    • Java容器
    • Java并发编程
    • Java虚拟机
  • 计算机基础

    • 数据结构与算法
    • 计算机网络
    • 操作系统
    • Linux
  • 框架|中间件

    • Spring
    • MySQL
    • Redis
    • MQ
    • Zookeeper
    • Git
  • 架构

    • 分布式
    • 高并发
    • 高可用
    • 架构
  • 框架

    • React
    • 其他
  • 实用工具
  • 安装配置

    • Linux
    • Windows
    • Mac
  • 开发工具

    • IDEA
    • VsCode
  • 关于
  • 收藏
  • 草稿
  • 索引

    • 分类
    • 标签
    • 归档
GitHub (opens new window)
  • 基础

  • 框架

    • React

      • React入门
      • React组件
      • DOM的Diffing算法
        • 证明Diffing算法存在
        • key的作用
      • React脚手架介绍
      • React简单案例
      • React路由
      • redux
      • 井字棋
    • 其他

  • Node

  • 前端
  • 框架
  • React
Marvel
2023-08-21
目录

DOM的Diffing算法

# DOM的Diffing算法

# 证明Diffing算法存在

案例:更新页面上的时间

输入框input的内容不会改变,但页面显示的时间会变化,说明只有更新部分发生改变了。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <!-- 准备好“容器” -->
    <div id="test"></div> <br><br><br>

    <script type="text/javascript" src="../React-js/17.0/react.development.js"></script>
    <script type="text/javascript" src="../React-js/17.0/react-dom.development.js"></script>
    <script type="text/javascript" src="../React-js/babel.min.js"></script>
    <script type="text/javascript" src="../React-js/17.0/prop-types.js"></script>  
    <script type="text/babel">
        class Time extends React.Component {
            state = {date: new Date()}
            componentDidMount(){
                setInterval(() => {
                    this.setState({
                        date: new Date()
                    })
                }, 1000)
            }
            render(){
                return (
                    <div>
                        <h1>hello</h1>
                        <input type="text"/>
                        <span>现在是: {this.state.date.toTimeString()}</span>    
                    </div>
                )
            }
        }

        ReactDOM.render(<Time/>, document.getElementById('test'))
    </script>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40

# key的作用

问法1:react/vue中key的作用?或者说,key的内部原理是什么?

问法2:为什么遍历列表时,key最好不要用index?

  1. 虚拟DOM中key的作用

    • 简单的说:key是虚拟DOM对象的标识,在更新显示时key起着极其重要的作用

    • 详细的说:当状态中的数据发生变化时,React会根据【新数据】生产【新的虚拟DOM】,随后React进行【新虚拟DOM】与【旧虚拟DOM】的diff比较,比较规则如下:

      1. 旧虚拟DOM中找到了与新虚拟DOM相同的key
        1. 若虚拟DOM中内容没变,直接使用之前的真实DOM
        2. 若虚拟DOM中内容改变,则生产新的真实DOM,随后替换掉页面中之前的真实DOM
      2. 旧虚拟DOM中未找到与新虚拟DOM相同的可以
        • 根据数据创建新的真实DOM,随后渲染到页面
  2. 用index作为key可能引发的问题:

    1. 若对数据进行逆序添加、逆序删除等破坏顺序操作。会产生没有必要的真实DOM更新,界面没问题,但效率低;
    2. 如果结构中包含输入类DOM,会产生错误DOM更新,界面有问题;
    3. 如果不存在对数据的逆序添加、逆序删除等破坏顺序操作,仅渲染列表用于展示,使用index作为key没有问题
  3. 选择key的方式

    1. 使用每条数据的唯一标识作为key,如id、手机号、身份证、学号等唯一值。
    2. 如果确定只是简单的展示数据,可以使用index
编辑 (opens new window)
上次更新: 2023/08/21, 20:05:58
React组件
React脚手架介绍

← React组件 React脚手架介绍→

最近更新
01
位运算
05-21
02
二叉树
05-12
03
Spring三级缓存解决循环依赖
03-25
更多文章>
Theme by Vdoing | Copyright © 2022-2024 Marvel
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式