微信小程序:网络请求

267 阅读2分钟

小程序中的网络请求

在小程序中,使用 wx.request( ) 这个方法来发送网路请求,整个请求的方式和 jQuery 里面的 $.ajax 方法是非常相似的。

在 wx.request( ) 这个方法中,接收一个配置对象,该配置对象中能够配置的项目如下表:

image-20230112100111671

为了解决uni.request网络请求API相对简单的问题(无法进行请求和相应拦截),可使用@escook/request-miniprogram进行网路请求的处理

参考地址:www.npmjs.com/package/@es…

下载时可以直接clone https://github.com/liulongbin1314/request-miniprogram.git 到项目里引用

在小程序中,无法使用fetch及axios进行网络请求发送

关于服务器接口

有关服务器接口的配置,需要满足以下两点:

  • 要求必须要是 https 接口
  • https 接口对应的域名还必须要在小程序管理平台进行配置

【开发】-【开发管理】-【开发设置】下面有一个【服务器域名】,在这个位置进行配置,配置完成需要重新打开项目才能生效

image-20230112100715734

我如果是开发环境怎么办?

在开发环境下,因为开发阶段的服务器接口还没部署到现网的域名下,所以我们可以选择不校验 HTTPS 证书,具体的方式如下图所示:

image-20230112101115812

向服务器传递参数

一般来讲,用得比较多的有 GET 和 POST 请求

  • GET
    • 可以放在 URL 后面(URL 长度有限制,并且还会做一次 URL 的 encode)
    • 也可以放在 data 配置项目里面
  • POST
    • 只能放在 data 里面

综上所述,建议就把数据放在 data 里面

收到回包

只要收到了服务器返回的信息,都会进入到 success 的回调函数,然后我们再在 success 回调函数中根据服务器返回的内容来做下一步操作。

// 向服务器发送 Get 请求
sendGet(){
  wx.request({
    url: 'http://localhost:3000',
    data : {
      loginId : this.data.loginId,
      password : this.data.password
    },
    success(e){
      console.log(e);
    }
  })
},
  // 向服务器发送 Post 请求
  sendPost(){
    wx.request({
      url: 'http://localhost:3000/abc',
      method : "POST",
      data : {
        loginId : this.data.loginId,
        password : this.data.password
      },
      success(e){
        console.log(e);
      }
    })
  },

使用技巧

一般来讲,在发送请求的时候,有三点可以优化:

  • 和服务器通信的过程中,需要显示一个 loading 框
    • wx.showLoading( ):显示 loading 框
    • wx.hideLoading( ):隐藏 loading 框
  • 设置超时时间
    • 在 app.json 中设置 networkTimeout
  • 如果处理失败,需要显示一个提示
    • wx.showToast( )

官方文档:developers.weixin.qq.com/ebook?actio…