小程序中如何使用wx:key提升wx:for的渲染效率

小编给大家分享一下小程序中如何使用wx:key提升wx:for的渲染效率,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

广安网站建设公司创新互联建站,广安网站设计制作,有大型网站制作公司丰富经验。已为广安超过千家提供企业网站建设服务。企业网站搭建\外贸网站建设要多少钱,请找那个售后服务好的广安做网站的公司定做!

小程序中使用 wx:key 提升 wx:for 的渲染效率

之所以加上 wx:key 会提升 wx:for 的渲染效率,原因是(我的初步理解)

  • 如果不加 wx:key, 在 setData 之后,如果 array 内的数据如果发生改变,会重新创建前端的渲染对象

  • 加上 wx:key,重新渲染时,只是将对应的对象重新排序。未发生变化的对象,不会重新创建

参考官方的解释

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

需要验证的问题

加上 wx:key 之后,会根据给定的 key 进行排序么?

写个简单的测试页面


  {{ language.id }} . {{ language.name }}


data: {
  languages: [
    {id: 1, name: 'php'},
    {id: 4, name: 'javascript'},
    {id: 3, name: 'golang'},
    {id: 2, name: 'python'},
    {id: 5, name: 'java'},
  ],
},

小程序中如何使用wx:key提升wx:for的渲染效率

从测试结果来看,并不会影响到排序。

key 重名时是否会报错

data: {
  languages: [
    {id: 1, name: 'php'},
    {id: 4, name: 'javascript'},
    {id: 3, name: 'golang'},
    {id: 2, name: 'python'},
    {id: 5, name: 'java'},
  ],
},

click: function () {
	let language = {id: 5, name: 'kotlin'}
	let languages = this.data.languages
	languages.push(language)

	this.setData({
		languages: languages
	})
}

微信小程序开发工具只会报一个警告,并不会导致程序崩溃

VM6265:2 Do not set same key {5} in wx:key

比较奇怪的是,这个警告只有在重新渲染时才会报,如果初始化时就使用同样的 key,并不会导致警告。

以上是“小程序中如何使用wx:key提升wx:for的渲染效率”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


当前文章:小程序中如何使用wx:key提升wx:for的渲染效率
文章转载:http://bzwzjz.com/article/jhchdd.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都定制网站建设 网站设计制作报价 成都商城网站制作 专业网站建设 企业网站设计 成都网站制作 成都网站建设公司 成都网站建设 网站制作报价 成都网站建设 手机网站设计 成都网站制作 成都网站建设 成都网站设计制作公司 泸州网站建设 成都企业网站建设 专业网站设计 定制网站制作 定制级高端网站建设 重庆企业网站建设 成都响应式网站建设 响应式网站设计方案