微信小程序 - 01 - 一些补充和注意点(补充ing...)

目录

最近在学微信小程序,把学习过程中的一些补充和注意点总结一下,内容会比较简单,因为只涉及基础知识,供个人参考

一、节流

情景:有一个按钮,点击会发送请求,用户可能会连续点击,但是我想即便在用户连续点击按钮的情况下,只有上一个请求发送完毕后,才能发送下一个请求

javascript 复制代码
data: {
    isLoading: false
}
// 发请求
getNameList() {
    this.setData({
        isLoading: true // 开启节流,相当于锁住了    
    })
    wx.request({
        url: 'xxx',
        method: 'GET',
        complete: () => {
            // 关闭节流,相当于打开锁
            this.setData({
                isLoading: false            
            })        
        }    
    })
}
// 事件,里面需要发请求
changeName() {
    if(this.data.isLoading) return // isLoading为true,说明上一个请求还在发送中,这时候不能再次发送请求
    getNameList()
}

二、在一个发请求的函数中,只有发生下拉动作,才执行关闭下拉代码

情景:用户发生下拉刷新的动作,于是触发函数,向后端发送请求,在请求结束后,要关闭下拉刷新的效果。但是这个函数不是只有下拉刷新的时候才触发,其他情况也要用到这个函数,我想只有发生下拉刷新才执行函数里的关闭下拉刷新代码,其余情况不执行

javascript 复制代码
  // 发请求获取id对应的数据
  getShopList(cb) {
    wx.request({
      url: `xxx`,
      method: 'GET',
      complete: () => {
        // 关闭下拉刷新的效果(只有下拉了,才需要关闭这个效果,其余情况不需要关闭)
        cb && cb()
      }
    })
  },
// 页面相关事件处理函数--监听用户下拉动作
  onPullDownRefresh() {
    // 重新发起数据请求
    this.getShopList(() => { // 传递了关闭下拉刷新的代码,在getShop函数里会执行该代码
      wx.stopPullDownRefresh()
    })
  },
// 普通事件
changeShop() {
	getShopList() // 没有传递参数,则在getShop函数里不会执行关闭下拉刷新的代码
}
相关推荐
正小安4 小时前
微信小程序 实现上拉加载更多功能:从基础到优化
微信小程序·小程序
I592O9297835 小时前
易经八字命理国学小程序开发
小程序
R_187819115348 小时前
相亲交友系统源码开发:构建高效互动平台的技术探索
java·微信小程序·intellij-idea·交友
说私域9 小时前
开源2+1链动模式AI智能名片小程序在短视频创业中的应用与机遇
人工智能·小程序
茶卡盐佑星_9 小时前
vue双向绑定/小程序双向绑定区别
前端·vue.js·小程序
Java追光着9 小时前
微信小程序开发-配置文件详解
微信小程序·小程序
千里码aicood10 小时前
[含文档+PPT+源码等]精品基于Nodejs实现的家教服务小程序的设计与实现
小程序
正小安11 小时前
微信小程序 详情图片预览功能实现详解
微信小程序·小程序
说私域13 小时前
升维定位在开源AI智能名片2+1链动模式S2B2C商城小程序中的应用与价值
人工智能·小程序