react里的key,加不加key,到底有啥不一样?图例+代码说明

2024-04-28 04:18

本文主要是介绍react里的key,加不加key,到底有啥不一样?图例+代码说明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家好,我是梅巴哥er ,本篇介绍的是react里的key

key的作用:

  • 提高状态的更新效率,减少不必要的DOM操作
  • 方便识别出是哪些状态在变化。

key的位置:

  • 放在map生成的第一li或div标签里

key的值:

  • 一般是元素的id值

下面以图例+代码的形式,来直观展示key的作用。

首先,先来看一下没有key的效果:

import React, { Component } from 'react'class App3 extends Component {constructor(props) {super(props) this.state = {list: [{id: 1, value: '值1'},{id: 2, value: '值2'},{id: 3, value: '值3'}]}}handleClick = () => {this.setState({list: [{id: 4, value: '值4'},{id: 1, value: '值1'},{id: 2, value: '值2'},{id: 3, value: '值3'}]})}render() {return (<div><button onClick={this.handleClick}>点击↓</button><ul>{this.state.list.map((v) => {return (// 这里没有设置key值<li>{ v.value }</li>)})}</ul></div>)}
}export default App3 

打开F12,点击按钮,看下运行的效果图:
在这里插入图片描述
看右侧代码,发现当点击按钮时,右侧4个li都发生了变化。说白了,就是原来的3个li,删除了,然后把这4个又重新生成了一遍。

再来看下设置了key值的效果:

import React, { Component } from 'react'class App3 extends Component {constructor(props) {super(props) this.state = {list: [{id: 1, value: '值1'},{id: 2, value: '值2'},{id: 3, value: '值3'}]}}handleClick = () => {this.setState({list: [{id: 4, value: '值4'},{id: 1, value: '值1'},{id: 2, value: '值2'},{id: 3, value: '值3'}]})}render() {return (<div><button onClick={this.handleClick}>点击↓</button><ul>{this.state.list.map((v) => {return (// 这里设置了key值<li key={ v.id }>{ v.value }</li>)})}</ul></div>)}
}export default App3 

打开F12,点击按钮,看下代码的变化:
在这里插入图片描述
看右侧代码,点击按钮的时候,只有新增的li发生了变化,原来3个li都没有发生变化。

这篇关于react里的key,加不加key,到底有啥不一样?图例+代码说明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942313

相关文章

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

ITMS-90339: Deprecated Info.plist Key

The Info.plist contains a key 'UIApplicationExitsOnSuspend' in bundle 在info.plist中找到这个key——UIApplicationExitsOnSuspend,然后删掉就可以了。确保没问题的话也跑一下看是否可以能在后台运行。 需要先转换一下,才能找到对应的key

Java面试题:通过实例说明内连接、左外连接和右外连接的区别

在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。 表示例 假设有两个表:Customers 和 Orders。 Customers CustomerIDCus

公共筛选组件(二次封装antd)支持代码提示

如果项目是基于antd组件库为基础搭建,可使用此公共筛选组件 使用到的库 npm i antdnpm i lodash-esnpm i @types/lodash-es -D /components/CommonSearch index.tsx import React from 'react';import { Button, Card, Form } from 'antd'

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

17.用300行代码手写初体验Spring V1.0版本

1.1.课程目标 1、了解看源码最有效的方式,先猜测后验证,不要一开始就去调试代码。 2、浓缩就是精华,用 300行最简洁的代码 提炼Spring的基本设计思想。 3、掌握Spring框架的基本脉络。 1.2.内容定位 1、 具有1年以上的SpringMVC使用经验。 2、 希望深入了解Spring源码的人群,对 Spring有一个整体的宏观感受。 3、 全程手写实现SpringM

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con