收藏
回答

wx:for渲染控制个数

请问用wx:for列表渲染如何限制一次渲染的个数,比如一共有10个对象,页面完成加载时先渲染5个,等用户触发上拉事件后再渲染后5个对象。

回答关注问题邀请回答
收藏

6 个回答

  • maq
    maq
    2017-06-16
    <block wx:for="{{list}}">
        <view hidden="{{index >= 5 && !showAll}}">
            ...
        </view>
    </block>


    2017-06-16
    有用 1
    回复 1
    • 2019-11-25
      立竿见影
      2019-11-25
      回复
  • 2017-07-28


    请问楼上,我本来有10条数据,但是手机上显示5条就满屏了,后面几条也没有显示出来是为什么呢???屏幕上拉都没有显示出来,请教一下。

    2017-07-28
    有用
    回复
  • maq
    maq
    2017-06-16

    想想办法嘛……

    <block wx:for="{{list}}">
        <view hidden="{{index >= showLimit}}">
            ...
        </view>
    </block>
    onReachBottom: function() {
        var that = this;
        this.setData({
           showLimit: that.data.showLimit + 5
       });
    }

    这样就可以了嘛。

    2017-06-16
    有用
    回复
  • 2017-06-16

    那如果我有20个对象,每次加载5个对象,就实现不了了,只能第一次显示5个对象,然后第二次就直接把所有对象都显示出来了

    2017-06-16
    有用
    回复
  • maq
    maq
    2017-06-16

    修改 showAll 这个属性值就可以控制超过 5 的那些对象是否显示。

    onReachBottom: function() {

        this.setData({

           showAll: true

       });

    }


    2017-06-16
    有用
    回复
  • 2017-06-16

    但是这个方法好像不能用onReachBottom动态修改他显示的个数啊

    2017-06-16
    有用
    回复
登录 后发表内容