小程序列表下拉刷新和加载更多

配置

在小程序的app.json中,检查window项目中是否已经加入了"enablePullDownRefresh": true,这个用来开启下拉刷新

  "window": {
   
    "backgroundTextStyle": "light",
    "navigationBarBackgroundColor": "#fff",
    "navigationBarTitleText": "洛塔",
    "navigationBarTextStyle": "black",
    "enablePullDownRefresh": true
  },

样式

直接引入weui

@import "/pages/style/weui.wxss";

布局

上方两个查询条件和一个按钮,下方显示列表
在这里插入图片描述

<view class="container">
  <view class="page-body">
    <form catchsubmit="formSubmit">
      <view class="weui-cells weui-cells_after-title">
        <view class="weui-cell weui-cell_input">
          <input name="shipName" class="weui-input" auto-focus placeholder="请输入船名,中英文均可"/>
        </view>
        <view class="weui-cell weui-cell_input">
          <input name="voyage" class="weui-input" placeholder="请输入航次号"/>
        </view>
    </view>
    <button type="primary" formType="submit" style="width:100%;margin-top: 10px;">查询船动态</button>
    </form>

    <view style="margin-top:10px; padding:10px; background:#eeeeee;" wx:for="{
   {list}}" wx:key="key">
    <view>
      <text style="font-size: 14px;"> 英文船名: {
   {
   item.shipNameEn}}</text>
    </view>
    <view>
      <text style="font-size: 14px;"> 中文船名: {
   {
   item.shipNameCn}}</text>
    </view>
    <view>
      <text style="font-size: 14px;"> 航次: {
   {
   item.voyage}}</text>
    </view>
    <view>
      <text style="font-size: 14px;"> 码头: {
   {
   item.wharf}}</text>
    </view>
    <view>
      <text style="font-size: 14px;"> 类型: {
   {
   item.type}}</text>
    </view>
    <view>
      <text style="font-size: 14px;"> 开港时间: {
   {
   item.startTime}}</text>
    </view>
    <view>
      <text style="font-size: 14px;"> 截关时间: {
   {
   item.endTime}}</text>
    </view>


    </view>

  </view>
</view>

逻辑

data中定义几个参数,分别对应请求参数和返回结果。

  data: {
   
    page:1,
    total:0,
    shipName:'',
    voyage:'',
    list:[]
  },

定义一个公共的请求方法,用来调用接口,加载更多、下来刷新、点击查询等,都调用这个方法

    getListInfo:function() {
   
      var url = 'https://eladmin.luotayixing.com/api/yzt/time?pageNumber=' + this.data.page +'&pageSize=10&shipName=' + this.data.shipName + '&voyage=' + this.data.voyage;
      var that = this;
      wx.showLoading({
   
        title: '加载中',
      })
      wx.request({
   
        url: url,
        success (res) {
   
          wx.hideLoading();
          if(that.data.page == 1) {
   
            that.setData({
   
              list: res.data.data.data
            })
          } else {
   
            var itemList = that.data.list;
            that.setData({
   
              list: itemList.concat(res.data.data.data)
            })
          } 
          that.setData({
   page: that.data.page+1});
          that.setData({
   total:res.data.data.total});
        },
        fail: function (res) {
   
          wx.hideLoading()
        }
      })
    },

点击查询按钮,直接调用上面的方法

    formSubmit(e) {
   
      this.setData({
   
        shipName:e.detail.value.shipName,
        voyage:e.detail.value.voyage,
        page:1
      });
      this.getListInfo();
    },

用户下拉刷新,需要把页码设置成1,然后调用方法

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {
   
      this.setData({
   page:1});
      this.getListInfo();
    },

加载更多,需要判断下是不是还有数据。

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {
   
      if (this.data.list.length != this.total) {
   
        this.getListInfo();
      } else {
   
        wx.showToast({
   
          title: '没有更多数据',
        })
      }
    },

以上就是全部逻辑了,完整的js文件如下:

Component({
   

  /**
   * 组件的属性列表
   */
  properties: {
   

  },

  /**
   * 组件的初始数据
   */
  data: {
   
    page:1,
    total:0,
    shipName:'',
    voyage:'',
    list:[]
  },

  /**
   * 组件的方法列表
   */
  methods: {
   
    getListInfo:function() {
   
      var url = 'https://eladmin.luotayixing.com/api/yzt/time?pageNumber=' + this.data.page +'&pageSize=10&shipName=' + this.data.shipName + '&voyage=' + this.data.voyage;
      var that = this;
      wx.showLoading({
   
        title: '加载中',
      })
      wx.request({
   
        url: url,
        success (res) {
   
          wx.hideLoading();
          if(that.data.page == 1) {
   
            that.setData({
   
              list: res.data.data.data
            })
          } else {
   
            var itemList = that.data.list;
            that.setData({
   
              list: itemList.concat(res.data.data.data)
            })
          } 
          that.setData({
   page: that.data.page+1});
          that.setData({
   total:res.data.data.total});
        },
        fail: function (res) {
   
          wx.hideLoading()
        }
      })
    },
    formSubmit(e) {
   
      this.setData({
   
        shipName:e.detail.value.shipName,
        voyage:e.detail.value.voyage,
        page:1
      });
      this.getListInfo();
    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {
   
      this.setData({
   page:1});
      this.getListInfo();
    },
    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {
   
      if (this.data.list.length != this.total) {
   
        this.getListInfo();
      } else {
   
        wx.showToast({
   
          title: '没有更多数据',
        })
      }
    },
    /**
     * 用户点击右上角分享
     */
    onShareAppMessage: function () {
   

    }
  }
})

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-19 07:20:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-19 07:20:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-19 07:20:03       82 阅读
  4. Python语言-面向对象

    2024-02-19 07:20:03       91 阅读

热门阅读

  1. docker容器单机部署zookeeper+kafka集群

    2024-02-19 07:20:03       43 阅读
  2. 在 CentOS 上安装 JDK 1.8

    2024-02-19 07:20:03       49 阅读
  3. 通俗易懂,Spring Bean生命周期管理的理解

    2024-02-19 07:20:03       48 阅读
  4. Kubernetes基础(二十)-k8s存储对象Storage Classes

    2024-02-19 07:20:03       54 阅读
  5. Backtrader 文档学习- 整体架构功能分析理解

    2024-02-19 07:20:03       46 阅读
  6. RabbitMQ

    RabbitMQ

    2024-02-19 07:20:03      39 阅读
  7. c++内存的四大分区详解

    2024-02-19 07:20:03       34 阅读
  8. Linux shell 命令中nohup 、&、重定向的使用

    2024-02-19 07:20:03       50 阅读