资讯专栏INFORMATION COLUMN

微信小程序入门教程--列表渲染多层嵌套循环及wx:key的使用

tracy / 721人阅读

摘要:前言入门教程之列表渲染多层嵌套循环,目前官方的文档里,主要是一维数组列表渲染的案例,还是比较简单单一,给刚入门的童鞋还是无从入手的感觉。我们也会不定期发布一些微信小程序的学习教程。需要入群的小伙伴,请加我的个人微信。

前言

入门教程之列表渲染多层嵌套循环,目前官方的文档里,主要是一维数组列表渲染的案例,还是比较简单单一,给刚入门的童鞋还是无从入手的感觉。


  {{index}}: {{item.message}}

还有一个九九乘法表把数据直接写到wxml里的,并不是动态二维数组的列表渲染。


  
    
      {{i}} * {{j}} = {{i * j}}
    
  

那么今天,我们主要来讲讲动态多维数组和对象混合的列表渲染。

讲解

何为多维数组和对象混合,给个很简单的例子

 twoList:[{
                id:1,
                name:"应季鲜果",
                count:1,
                twodata:[{
                    "id":11,
                    "name":"鸡脆骨"
                },{
                    "id":12,
                    "name":"鸡爪"
                }]
        },{
                id:2,
                name:"精致糕点",
                count:6,
                twodata:[{
                    "id":13,
                    "name":"羔羊排骨一条"
                },{
                    "id":14,
                    "name":"微辣"
                }]
        }]

上述例子就是一个数组,这都是我们日常开发过程中,经常会碰到的JSON格式,
该数组的元素是有对象,对象又分为属性,属于数组对象混合,可能对于刚接触小程序的童鞋,碰到这种数组对象混合的就会发难了。

一层循环
    oneList:[{
                id:1,
                name:"应季鲜果",
                count:1
        },{
                id:2,
                name:"精致糕点",
                count:6
        },{
                id:3,
                name:"全球美食烘培原料",
                count:12
        },{
                id:4,
                name:"无辣不欢生猛海鲜",
                count:5
        }]

以上数组对象混合JSON,是测试只有一层循环的,我们看看在wxml里怎么循环,我们先看一下要循环渲染到页面上的效果图。


    {{index+1}}、{{item.name}}

我们可以看到,这里直接用两个花括号来给view 循环列表,注意强调一下,请记得一下要用 两个花括号数据起来,如果不包起来,view也会循环出来,但并不是自己要循环的数据,而且是给了一个假象给你以为是有循环了,这里开发工具有点坑人的感觉,这个还需要多细心点,这里记住一点,只要是有数据的,就需要花括号。
另外默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item,同时我这里也顺道演示了如何使用数组变量名和下标。

二层循环

JSON代码

        twoList:[{
                id:1,
                name:"应季鲜果",
                count:1,
                twodata:[{
                    "id":11,
                    "name":"鸡脆骨"
                },{
                    "id":12,
                    "name":"鸡爪"
                }]
        },{
                id:2,
                name:"精致糕点",
                count:6,
                twodata:[{
                    "id":13,
                    "name":"羔羊排骨一条"
                },{
                    "id":14,
                    "name":"微辣"
                }]
        },{
                id:3,
                name:"全球美食烘培原料",
                count:12,
                twodata:[{
                    "id":15,
                    "name":"秋刀鱼"
                },{
                    "id":16,
                    "name":"锡箔纸金针菇"
                }]
        }]

wxml代码

        
            
                {{index+1}}、{{item.name}}
            
            
                ----{{twodata.name}}---{{item.name}}
            
        

以上截图和代码是二层嵌套内容。
我们在wxml代码里,很明显的看到有两个wx:for的控制属性,在二层循环的JSON代码里,我们看每个单数组里还有一级数据twodata,这里是需要再循环渲染到页面上的,在第一层数据里,直接再循环item.twodata即可,请记得一定要带上花括号。
在第二层的循环里,建议把当前项的变量名改为其他,即在wxml代码里看到的 wx:for-item="twodata",因为默认的当前项的变量名为item,如果不改换其他的话,你是拿不到第一层循环的数据的,因为被第二层的变量名覆盖了。
所以我们在wxml代码里,在第二层循环时,可以看到还可以循环第一层的值,即----{{twodata.name}}---{{item.name}}

三层以上的多层循环

三层以上的多层的数组循环,在原理上同二层循环是一样的,能理解了二层数组循环,对于三层以及三层以上都能得心应用的。
需要注意的地方,那就是老生常谈的问题了,数据需要用花括号括起来,从第二层起,把默认的当前项的变量名改为其他,例如 wx:for-item="twodata",还有细心再细心。

wx:key唯一标识符

为什么会有wx:key的出现呢,官方给的解释是,如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如 input 中的输入内容,switch 的选中状态),需要使用 wx:key 来指定列表中项目的唯一的标识符。
当数据改变触发渲染层重新渲染的时候,会校正带有 key 的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。
在开发过程中,wx:key的作用对于项目作用是非常大的,如果从文字上无法理解的童鞋,可以到github clone demo到微信开发工具里,亲自体验下。

我们看到这个GIF动画图,这里有一个switch的开启状态,switch的状态是在标题为羔羊排骨一条的,在对这个数组增加数据时,这个switch的状态并不跟随着羔羊排骨一条,并不保持自己的状态。

那我们再看另一个例子,使用了wx:key唯一标识符。

这个GIF动画图,也是点击开启了switch的状态,唯一有不同的地方,就是在新增数据时,是保持着自己的状态的。
相信通过这两个小例子,对wx:key唯一标识符应该也有所了解啦,想要提升技术,就要多折腾,自己在小程序里,写个wx:forwx:key 体会下。

还有一个需要注意的地方,我们先看看以下代码


wx:key="id",我们看到wx:key里的值并不需要花括号的,是的,这里是比较特别的地方,不需要花括号,同时也不需要参数名,需要是虽然数据里的一个字段名。

结束语

今天我们讲了列表渲染,官方给的文档还是比较简单单一,我们这里更深入的讲了数组的一层、二层以及多层循环,还有wx:key唯一标识符的使用方法和注意事项。

相信在小程序推出公测之后,很多小伙伴都已经抓紧申请注册小程序了。在开发阶段中也碰到了很多的问题,例如wx.request数据请求不成功,在数组操作时,不知道如何往数组里push数据,input如何监听用户输入的状态,css的background-image无法获取本地资源等等,本博客会出一个专题,给碰到这些问题的小伙伴解决思路。

demo github地址:
https://github.com/bluefox168...

交流平台

最近大家对微信小程序开发热情大涨,结识了不少对微信小程序技术开发的牛人,也有一些刚入行的新手,特此我建立了一个微信小程序技术交流圈子,希望给大伙有一个纯洁的技术交流圈子,技术交流,提升自我。我们也会不定期发布一些微信小程序的学习教程。
此群的目标为纯(干)纯(货)的技术交流群,不死于广告之中,已开启了群主邀请确认机制。
需要入群的小伙伴,请加我的个人微信amwhuang。(备注:小程序入群)

文章首发地址:
列表渲染多层嵌套循环及wx:key的使用--微信小程序入门教程
http://lanchenglv.com/article...
如需转载,请标明转载出处,谢谢。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/54371.html

相关文章

  • 信小程序入门教程--列表渲染多层嵌套循环wx:key使用

    摘要:前言入门教程之列表渲染多层嵌套循环,目前官方的文档里,主要是一维数组列表渲染的案例,还是比较简单单一,给刚入门的童鞋还是无从入手的感觉。我们也会不定期发布一些微信小程序的学习教程。需要入群的小伙伴,请加我的个人微信。 前言 入门教程之列表渲染多层嵌套循环,目前官方的文档里,主要是一维数组列表渲染的案例,还是比较简单单一,给刚入门的童鞋还是无从入手的感觉。 {{index}}: {...

    Luosunce 评论0 收藏0
  • 信小程序(一)

    摘要:微信小程序一介绍微信小程序可以说是网页的进阶版,同样的功能,它可以更加便利。微信小程序是需要下载的,但是微信审核要小程序代码一下,所以这个下载相当于不用下载。 微信小程序(一) 介绍 微信小程序可以说是网页的进阶版,同样的功能,它可以更加便利。微信小程序是需要下载的,但是微信审核要小程序代码1M一下,所以这个下载相当于不用下载。 小程序官网地址 微信小程序对比软件: 小巧轻便,无...

    Imfan 评论0 收藏0
  • 信小程序】关于信小程序多层嵌套渲染列表嵌套列表中数据获取

    摘要:起因意图是想实现类似于安卓那样的效果,想到了用微信小程序的组件,但如果每个里都只用一个来渲染数据的话实在是太慢了,就想到多层嵌套数据渲染来提高效率。 起因:意图是想实现类似于安卓viewpager那样的效果,想到了用微信小程序的swiper组件,但如果每个swiper-item里都只用一个wx:for来渲染数据的话实在是太慢了,就想到多层嵌套数据渲染来提高效率。 直接上代码 wxml:...

    mushang 评论0 收藏0
  • 信小程序】关于信小程序多层嵌套渲染列表嵌套列表中数据获取

    摘要:起因意图是想实现类似于安卓那样的效果,想到了用微信小程序的组件,但如果每个里都只用一个来渲染数据的话实在是太慢了,就想到多层嵌套数据渲染来提高效率。 起因:意图是想实现类似于安卓viewpager那样的效果,想到了用微信小程序的swiper组件,但如果每个swiper-item里都只用一个wx:for来渲染数据的话实在是太慢了,就想到多层嵌套数据渲染来提高效率。 直接上代码 wxml:...

    刘东 评论0 收藏0

发表评论

0条评论

tracy

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<