zoukankan      html  css  js  c++  java
  • 小程序:怎么在两层列表循环(wx:for)的时候判断是否为最后一个元素

    问题说明:

       如下图所示,在箭头所指的最后一个选项的底线与底部操作栏的上边线重叠,需要清除掉最后一个元素的底线;

       想到的解决方案:

       通过判断是否为最后一个元素,然后通过条件渲染(wx:if)动态添加对应的底线样式: .bottom-line

    然后开始写代码,第一版如下:

      <view class="vote-item" wx:for="{{votes}}">
            <view class="vote-item-hd">
                <image src="{{item.data.user.avatar_url}}" mode="aspectFill"></image>
                <view class="vote-item-hd-info">
                    <view class="nickname">{{item.data.user.nick_name}}</view>
                    <view>{{item.time_for_humans}}</view>
                </view>
            </view>
            <view class="vote-item-con">
                <view class="vote-item-con-hd bottom-line">
                    {{item.data.content}}
                </view>
                <view wx:for="{{item.data.options}}" >
                    <view wx:if="{{index === item.data.options.length-1}}" class="vote-item-data" hover-class="vote-item-data-active">
                          {{item.title}}
                    </view>
                    <view wx:else class="vote-item-data bottom-line"  hover-class="vote-item-data-active">
                          {{item.title}}
                    </view>
                </view>
            </view>
            <view class="vote-item-ft top-line">
                <i class="fa fa-align-left"><text>21</text></i>
                <button open-type="share" plain="true"><i class="fa fa-retweet" bindtap="onShareAppMessage"></i></button>
            </view>
        </view>
    

      

     运行后发现:判断后的界面效果,没有任何改变;期间,我通过进行如下修改去打印:item.data.options.length

       <view wx:for="{{item.data.options}}" >
                    <view wx:if="{{index === item.data.options.length-1}}" class="vote-item-data" hover-class="vote-item-data-active">
                        {{item.data.options.length}}  {{item.title}}
                    </view>
                    <view wx:else class="vote-item-data bottom-line"  hover-class="vote-item-data-active">
                         {{item.data.options.length}} {{item.title}}
                    </view>
                </view>
    

    上述代码运行后,发现没有打印出来结果,不存在item.data.options.length

    研究了下文档,发现可能是外层列表的item变量名和内层列表的item冲突导致的,小程序官方文档也间接的给出了解决方案:

    小程序官方文档相关内容如下:

    通过示例,我们可以发现:可以使用wx:for-item 指定数组当前元素的变量名来解决内外层item的冲突

    于是,我通过  wx:for-item="vote" 让外层列表的变量名为vote,从而避免和内层的当前元素变量item冲突;

    顺利,通过  vote.data.options.length 获取选项的数组长度;通过条件渲染(wx:if)解决问题

    于是修改了下代码:

        <view class="vote-item" wx:for="{{votes}}" wx:for-item="vote">
            <view class="vote-item-hd">
                <image src="{{vote.data.user.avatar_url}}" mode="aspectFill"></image>
                <view class="vote-item-hd-info">
                    <view class="nickname">{{vote.data.user.nick_name}}</view>
                    <view>{{vote.time_for_humans}}</view>
                </view>
            </view>
            <view class="vote-item-con">
                <view class="vote-item-con-hd bottom-line">
                    {{vote.data.content}}
                </view>
                <view wx:for="{{vote.data.options}}" >
                    <view wx:if="{{index === vote.data.options.length-1}}" class="vote-item-data" hover-class="vote-item-data-active">
                         {{vote.data.options.length}}  {{item.title}}
                    </view>
                    <view wx:else class="vote-item-data bottom-line"  hover-class="vote-item-data-active">
                          {{vote.data.options.length}} {{item.title}}
                    </view>
                </view>
            </view>
            <view class="vote-item-ft top-line">
                <i class="fa fa-align-left"><text>21</text></i>
                <button open-type="share" plain="true"><i class="fa fa-retweet" bindtap="onShareAppMessage"></i></button>
            </view>
        </view>
    

      

     运行结果:重叠不见,问题解决

     

    总结:很多问题,小程序官方文档直接或间接的给出了解决方案;通过wx:for-item 指定数组当前元素的变量名,从而解决内外层item的冲突;

    从而可以在内层列表循环中获取外层列表对应的变量值,然后通过条件渲染(wx:if),从而实现对内层列表循环的最后一个元素进行动态添加边线样式( .bottom-line)。

  • 相关阅读:
    SQL 学习笔记<六> MySQL存储过程基础
    SQL 学习笔记<三> SELECT之连接查询
    六、Delphi10.3通过Json.Serializers单元对大量数据序列化
    七、Delphi10.3读取JSON数组
    五、Delphi10.3通过REST单元使类和JSON数据互相转换
    四、Delphi10.3读取JSON数据
    python格式化输出
    python基础知识02
    发送邮件实例
    python基础知识03
  • 原文地址:https://www.cnblogs.com/kevinCoder/p/8932197.html
Copyright © 2011-2022 走看看