# uni.request(param)

发起网络请求。

# request 兼容性

Web 微信小程序 Android Android uni-app x UTS 插件 iOS iOS uni-app x UTS 插件
4.0 4.41 3.91 3.91 4.11 4.11

# 参数

名称 类型 必填 默认值 兼容性 描述
param RequestOptions<T> - - 网络请求参数
名称 类型 必备 默认值 兼容性 描述
url string -
开发者服务器接口地址
data any null
请求的参数 在app-android端,参数类型只能为UTSJSONObject或者string`类型,app-android平台从 4.51版本开始支持ArrayBuffer
header UTSJSONObject null
设置请求的 header,header 中不能设置 Referer
method string "GET"
请求方法
合法值 兼容性 描述
GET - GET方法请求一个指定资源的表示形式,使用 GET 的请求应该只被用于获取数据。
POST - POST方法用于将实体提交到指定的资源,通常导致在服务器上的状态变化或副作用。
PUT - PUT方法用有效载荷请求替换目标资源的所有当前表示。
PATCH - PATCH方法用于对资源应用部分修改。
DELETE - DELETE方法删除指定的资源。
HEAD - HEAD方法请求一个与GET请求的响应相同的响应,但没有响应体。
OPTIONS - OPTIONS 方法用于描述目标资源的通信选项。
timeout number 60000
超时时间,单位 ms
withCredentials boolean -
跨域请求时是否携带凭证(cookies)
firstIpv4 boolean false
DNS解析时优先使用ipv4
success (option: RequestSuccess<T>) => void null - 网络请求成功回调。
fail (option: RequestFail) => void null - 网络请求失败回调。
complete (option: any) => void null - 网络请求完成回调,成功或者失败都会调用。

# RequestSuccess<T> 的属性值

名称 类型 必备 默认值 兼容性 描述
data T -
开发者服务器返回的数据
statusCode number -
开发者服务器返回的 HTTP 状态码
header any -
开发者服务器返回的 HTTP Response Header
cookies Array<string> -
开发者服务器返回的 cookies,格式为字符串数组

# RequestFail 的属性值

名称 类型 必备 默认值 兼容性 描述
errCode number - - 错误码
合法值 兼容性 描述
5 - 接口超时
1000 - 服务端系统错误
100001 - json数据解析错误
100002 - 错误信息json解析失败
600003 - 网络中断
600008 - data参数类型不合法
600009 - URL格式不合法
602001 - request系统错误
errSubject string - - 统一错误主题(模块)名称
data any - - 错误信息中包含的数据
cause Error - - 源错误信息,可以包含多个错误,详见SourceError
errMsg string - - -

# 返回值

类型
RequestTask

# RequestTask 的方法

# abort(): void

中断网络请求。

# abort 兼容性
Web 微信小程序 Android Android uni-app x UTS 插件 iOS iOS uni-app x UTS 插件
4.0 4.41 3.91 3.91 4.11 4.11

注意事项

  • 在4.25版本iOS平台增加了Task原生对象自动销毁的逻辑,即网络请求完成后自动释放原生的Task对象,建议开发者在complete回调中置空Task对象,例
complete: () => {
            this.task = null
          },

如不释放,在调用Task对象的方法将导致控制台报错: error: instance object does not exist: id:15

# 参见

# 示例

hello uni-app x

扫码体验(手机浏览器跳转到App直达页)

Template

Script

<template>
  <view style="flex: 1;">
    <view class="uni-padding-wrap uni-common-mt">
      <view class="uni-common-mt" style="border-width: 2px;border-style: solid; border-radius: 4px;">
        <textarea :value="res" class="uni-textarea" style="width: 100%;"></textarea>
      </view>
      <view>
        <text>地址 : {{ host + url}}</text>
        <text>请求方式 : {{method}}</text>
      </view>
      <view class="uni-btn-v uni-common-mt">
        <button type="primary" @click="sendRequest">发起请求</button>
      </view>
    </view>
    <scroll-view style="flex: 1;" show-scrollbar="true">
      <view style="padding: 20px;">
        <text>设置请求方式</text>
        <view class="uni-common-pb"></view>
        <view style="flex-direction: row;flex-wrap: wrap;">
          <button style="padding: 5px; margin-right: 10px;" type="primary" size="mini"
            @click="changeMethod('GET')">GET</button>
          <button style="padding: 5px; margin-right: 10px; " type="primary" size="mini"
            @click="changeMethod('POST')">POST</button>
          <button style="padding: 5px; margin-right: 10px; " type="primary" size="mini"
            @click="changeMethod('PUT')">PUT</button>
          <button style="padding: 5px; margin-right: 10px;" type="primary" size="mini"
            @click="changeMethod('DELETE')">DELETE</button>
          <button style="padding: 5px; margin-right: 10px; " type="primary" size="mini"
            @click="changeMethod('PATCH')">PATCH</button>
          <button style="padding: 5px;margin-right: 10px;" type="primary" size="mini"
            @click="changeMethod('OPTIONS')">OPTIONS</button>
          <button style="padding: 5px;" type="primary" size="mini" @click="changeMethod('HEAD')">HEAD</button>
        </view>
      </view>
      <view style="padding: 20px;">
        <text>请求返回错误码的接口(默认为GET)</text>
        <view class="uni-common-pb"></view>
        <view style="flex-direction: row;flex-wrap: wrap;">
          <button style="padding: 5px;" type="primary" size="mini" v-for="(item, index) in errorCodeUrls" :key="index"
            @click="changeUrl(item)">{{item}}</button>
        </view>
      </view>
      <view style="padding: 20px;">
        <text>请求不同header的接口(默认为GET)</text>
        <view class="uni-common-pb"></view>
        <view style="flex-direction: row;flex-wrap: wrap;">
          <button style="padding: 5px;" type="primary" size="mini" v-for="(item, index) in headerUrls" :key="index"
            @click="changeUrl(item)">{{item}}</button>
        </view>
      </view>
      <view style="padding: 20px;">
        <text>请求不同content-type的接口(默认为GET)</text>
        <view class="uni-common-pb"></view>
        <view style="flex-direction: row;flex-wrap: wrap;">
          <button style="padding: 5px;" type="primary" size="mini" v-for="(item, index) in contentTypeUrls" :key="index"
            @click="changeUrl(item)">{{item}}</button>
        </view>
      </view>

      <view style="padding: 20px;">
        <text>POST请求(有body)</text>
        <view class="uni-common-pb"></view>
        <view style="flex-direction: row;flex-wrap: wrap;">
          <button style="padding: 5px;" type="primary" size="mini" v-for="(item, index) in postUrls" :key="index"
            @click="changeUrlFromPost(item)">{{item}}</button>
        </view>
      </view>
    </scroll-view>
  </view>
</template>


# cookie管理

  • uni.requestuni.uploadFileuni.downloadFile等网络API之间支持共享cookie Cookie共享介绍

# 注意事项

  • 推荐使用成熟的网络拦截器插件,见插件市场
  • app-android平台 request 接口如需包装和传递泛型,需参考泛型传递丢失注意。成熟的拦截器插件均已自动处理这些问题。
  • 如果使用泛型先创建RequestOptions实例,再传入uni.request(),此时请务必确保request要显式指定泛型,例:
const options: RequestOptions<Person> = ...
uni.request<Person>(options)
  • app-android、app-ios平台 uni.request()暂未支持Promise,返回值是RequestTask。
  • app平台 request 暂不支持sse。可以使用web-view组件的网络来接受sse数据,也可以下载三方插件插件市场
  • web平台 request接口目前不支持创建传入的泛型的实例
  • web平台 request接口在 4.01版本之前返回数据是一个普通对象,4.01起调整为UTSJSONObject类型

由于uni-app x的强类型,导致联网相关开发有一些不同,请不熟悉强类型的开发者务必阅读教程:uni-app x的联网教程

# 通用类型

# GeneralCallbackResult

名称 类型 必备 默认值 兼容性 描述
errMsg string -
错误信息