DOM中的diff算法详解
admin
2024-02-12 10:16:53
0

经典面试题:

1.react/vue中的key有什么作用?key的内部原理是什么?

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

看完以下内容,轻松解决你对diff算法的认识以及以上两个常问问题。

虚拟DOM中key的作用:

1.当数据状态发生变化时,react/vue会根据新数据生成新的虚拟dom,随后会进行新旧dom的比较,比较规则如下:

①旧虚拟dom中找到了新虚拟dom相同的key:

(1)若虚拟dom中内容没变,直接使用之前的真实dom

(2)若虚拟dom中内容变了,则生成新的真实dom,并替换掉页面中之前的真实dom

②旧虚拟dom中未找到新虚拟dom相同的key:

(1)根据数据创建新的真实的dom,并渲染到页面

2.用index作为key可能会引发的问题

①若数据进行:逆序添加、逆序删除等破坏顺序的操作,此时会产生没有必要的真实的dom更新,虽然界面效果没什么问题,但效率低

②如果结构中还包含输入类的dom,会产生错误dom更新,界面会发生问题

③注意:如果不存在数据的逆序添加,逆序删除等破坏顺序性操作,仅用于渲染列表到页面,一般是没有问题的

3.开发中如何选择key值

①最好使用每条数据的唯一标识作为key,如id,身份证号等

②如果确定只是简单的展示数据,也可以用index

import React, { Component } from 'react'export default class ClassHanshu extends Component {constructor() {super()this.state = {persons: [{ id: 1, name: "张三", age: 18 },{ id: 2, name: "张四", age: 19 },]}}// 用index索引作为key时:// 初始数据: // { id: 1, name: "张三", age: 18 },// { id: 2, name: "张四", age: 19 },// 初始虚拟dom// 
  • 张三,18
  • //
  • 张四,19
  • // 页面更新后数据// { id: 3, name: "张五", age: 20 },// { id: 1, name: "张三", age: 18 },// { id: 2, name: "张四", age: 19 },// 页面更新后虚拟dom//
  • 张五,20
  • //
  • 张三,18
  • //
  • 张四,19
  • // 此时新旧虚拟dom根据key进行对比发现里面的内容变了,便替换掉了页面中之前真实的dom,而这意味着两条重复的数据没有重复利用,当数据庞大时效率可想而知add() {const { persons } = this.stateconst p = { id: persons.length + 1, name: "张五", age: 20 }this.setState({persons: [p, ...persons]})}render() {return (
      {this.state.persons.map((personObj, index) => {return
    • {personObj.name},{personObj.age}
    • })}
    )} }
    import React, { Component } from 'react'export default class ClassHanshu extends Component {constructor() {super()this.state = {persons: [{ id: 1, name: "张三", age: 18 },{ id: 1, name: "张四", age: 19 },]}}// 用id作为key时:// 初始数据: // { id: 1, name: "张三", age: 18 },// { id: 2, name: "张四", age: 19 },// 初始虚拟dom// 
  • 张三,18
  • //
  • 张四,19
  • // 页面更新后数据// { id: 3, name: "张五", age: 20 },// { id: 1, name: "张三", age: 18 },// { id: 2, name: "张四", age: 19 },// 页面更新后虚拟dom//
  • 张五,20
  • //
  • 张三,18
  • //
  • 张四,19
  • // 此时新旧虚拟dom根据key进行对比发现没有的便在页面渲染,有的并且内容一样的便用之前真实的domadd() {const { persons } = this.stateconst p = { id: persons.length + 1, name: "张五", age: 20 }this.setState({persons: [p, ...persons]})}render() {return (
      {this.state.persons.map((personObj) => {return
    • {personObj.name},{personObj.age}
    • })}
    )} }

    相关内容

    热门资讯

    消息称百度旗下昆仑芯瞄准500... 6 月 29 日消息,据《The Information》昨日援引知情人士消息,百度旗下 AI 芯片...
    打造夏日消费新场景 第35届北... 北京商报讯(记者 翟枫瑞)6月29日消息,第35届北京国际燕京啤酒文化节新闻发布会在京举行。本届啤酒...
    社保基金持仓数据出炉,一季度增... 最近各大上市公司一季度财报都公开了,咱们国家社保基金的持仓数据也全部曝光。目前社保拿着比亚迪价值44...
    36氪首发 | 海思、中兴团队... 作者 | 乔钰杰 编辑 | 袁斯来 硬氪获悉,广州宸思通讯科技有限公司(以下简称“宸思科技”)近日完...
    两天蒸发47亿市值!一纸税务通... 一纸税务通知书,能让一家百亿龙头两天蒸发47亿市值。 6月22日,北大荒(600598.SH)公告称...
    SK海力士将投资1100万亿韩... SK集团会长崔泰源6月29日在韩国“三大重大计划”发布会上宣布,公司将投资1100万亿韩元扩大半导体...
    两只A股,终止上市! 两家A股公司,即将摘牌。 6月29日,退市沪科(600608.SH)公告称,上海证券交易所将在202...
    原创 M... 一家成立近十年的自动驾驶公司,在IPO时吸引了14家基石投资者认购近一半的发行股份,其中不乏奔驰、比...
    基金忠言|国寿安保滤镜碎,三年... 图片来源:视觉中国 蓝鲸新闻6月29日讯(记者 祁和忠)保险系基金公司国寿安保总经理换人了。 6月2...
    三星电机计划加码玻璃基板!相关... 6月29日,玻璃基板概念股午后有所回升, 华工科技(000988.SZ)逼近涨停, 彩虹股份(600...
    拉萨海关持续壮大外贸经营主体 ...   新华网拉萨6月28日电(记者蒋梦辰)近日,记者从拉萨海关获悉,今年前5个月,西藏有进出口实绩的外...
    机构:二季报临近,医药生物板块... 6月29日,华源证券发布了一篇医药生物行业的研究报告,报告指出,业绩期临近,产业链景气度有望再次迎来...
    每日收评科创50放量涨超4.5... 财联社6月29日讯,三大指数全线收红,创业板指探底回升,科创50指数大涨4.61%。沪深两市成交额3...
    6月多地土拍结构性升温:深圳单... 进入2026年6月,不少城市核心区地块集中诞生高溢价宗地,热度突出的城市包含深圳、杭州、长沙。 其中...
    业绩炸裂!盛达资源半年预盈3.... 6月29日,贵金属矿山龙头盛达资源(000603.SZ)发布 2026 年半年度业绩预告,上半年业绩...
    A股午后拉升三大股指收涨:半导... A股三大股指6月29日开盘涨跌互现。早盘沪强深弱,创指一度跌超2%。半导体午后拉升,带动两市上涨,沪...
    原创 空... 前言 大家好,我是老金。 这几天,两幅极度割裂的画面放在一起,把我看笑了。 一边是在持续的热浪下,欧...
    澳大利亚审慎监管局拟放宽银行风... 澳大利亚审慎监管局(APRA)6月29日就修改 银行信用风险资本设定公开征求意见,旨在加大信贷投放以...
    全民炒股,急踩刹车!韩国股市突... 屈红燕/证券时报网 全民狂欢、交易高度拥挤、杠杆资金猛增、新入市投资者表现激进、大型IPO吸金等现象...