收藏
回答

有大佬可以直白的说一下wx:key用途吗?一直没怎么明白

问题模块 框架类型 问题类型 API/组件名称 终端类型 微信版本 基础库版本
API和组件 小程序 需求 wx:for 客户端 6.3.5 2.4.1

- 需求的场景描述(希望解决的问题)

了解wx:key的使用

- 希望提供的能力


最后一次编辑于  03-19  (未经腾讯允许,不得转载)
邀请回答
复制链接收藏投诉关注问题回答

3 个回答

  • 铭锋科技
    铭锋科技
    03-19

    如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如 <input/> 中的输入内容<switch/> 的选中状态),需要使用 wx:key 来指定列表中项目的唯一的标识符。

    wx:key 的值以两种形式提供
    1、wx:key="property" 其中property是代表在 for 循环的 array 中 item 的某个 property,该 property 的值需要是列表中唯一的字符串或数字,且不能动态改变。类似于字典的key值
    2、wx:key="*this", 保留关键字 *this 代表在 for 循环中的 item 本身,这种表示需要 item 本身是一个唯一的字符串或者数字,如:
    当数据改变触发渲染层重新渲染的时候,会校正带有 key 的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组
    件保持自身的状态,并且提高列表渲染时的效率。

    不添加wx:key情况:
    <block wx:for-items="{{userInfoList}}" >,会出现warning: Now you can provide attr "wx:key" for a "wx:for" to improve performance. 如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。

    推荐array 的 每一个item都添加一个唯一识别的property来管理,这样就可以去掉warning,如果使用保留关键字,好像会出现显示的item都是最后一个的
    <block wx:for-items="{{userInfoList}}" wx:key="userInfoListId">


    03-19
    赞同
    回复 3
    • Killer Irving
      Killer Irving
      03-19

      能在明白一点吗😂

      03-19
      回复
    • 铭锋科技
      铭锋科技
      03-19回复Killer Irving

      wx:key就是提高列表渲染效率的

      03-19
      回复
    • Killer Irving
      Killer Irving
      03-19回复铭锋科技

      nice,感谢

      03-19
      回复
  • 拾忆
    拾忆
    03-19

    wx:key

    如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如 <input> 中的输入内容,<switch> 的选中状态),需要使用 wx:key 来指定列表中项目的唯一的标识符。

    wx:key 的值以两种形式提供

    1. 字符串,代表在 for 循环的 array 中 item 的某个 property,该 property 的值需要是列表中唯一的字符串或数字,且不能动态改变。

    2. 保留关键字 *this 代表在 for 循环中的 item 本身,这种表示需要 item 本身是一个唯一的字符串或者数字,如:

    当数据改变触发渲染层重新渲染的时候,会校正带有 key 的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。

    如不提供 wx:key,会报一个 warning, 如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。


    03-19
    赞同
    回复 1
    • Killer Irving
      Killer Irving
      03-19

      看了文档,但是没看懂😂,想听听过来人的直白说法

      03-19
      回复
  • 卢霄霄
    卢霄霄
    03-19

    给你写了个demo,先把上下两个的第一个switch选中,然后点test


    https://developers.weixin.qq.com/s/lsZa6Ymi7o6V


    如果循环的是个对象类型的数组,你需要设置正确的属性;

    如果是个基本数据类型的数组,你需要设置*this;

    03-19
    赞同
    回复 3
    • Killer Irving
      Killer Irving
      03-19

      天!谢谢大佬,这个demo让我理解了文档的这句话:框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态

      03-19
      回复
    • 卢霄霄
      卢霄霄
      03-19回复Killer Irving

      天!有这么吃惊吗。。下班~

      03-19
      回复
    • Killer Irving
      Killer Irving
      03-19回复卢霄霄

      哈哈哈哈~~~~下班愉快啊

      03-19
      回复