uniapp项目中配置网络请求

Posted 老张在线敲代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了uniapp项目中配置网络请求相关的知识,希望对你有一定的参考价值。

//终端中安装
npm install @escook/request-miniprogram
在main.js中配置如下
import  $http  from '@escook/request-miniprogram'

uni.$http = $http
// 配置请求根路径
$http.baseUrl = 'https://www.uinav.com'

// 请求开始之前做一些事情
$http.beforeRequest = function (options) 
  uni.showLoading(
    title: '数据加载中...',
  )

// 封装的展示消息提示的方法
uni.$showMsg = function (title = '数据加载失败!', duration = 1500) 
  uni.showToast(
    title,
    duration,
    icon: 'none',
  )

// 请求完成之后做一些事情
$http.afterRequest = function () 
  uni.hideLoading()

配置完成后使用

<template>
  <view>
    <!-- 轮播图区域 -->
    <swiper :indicator-dots="true" :autoplay="true" :interval="3000" :duration="1000" :circular="true">
      <!-- 循环渲染轮播图的 item 项 -->
     <swiper-item v-for="(item, i) in swiperList" :key="i">
         <navigator class="swiper-item" :url="'/subpkg/goods_detail/goods_detail?goods_id=' + item.goods_id">
           <!-- 动态绑定图片的 src 属性 -->
           <image :src="item.image_src"></image>
         </navigator>
     </swiper-item>
    </swiper>
  </view>
</template>
 export default 
   data() 
     return 
       // 1. 轮播图的数据列表,默认为空数组
       swiperList: [],
     
   ,
   onLoad() 
     // 2. 在小程序页面刚加载的时候,调用获取轮播图数据的方法
     this.getSwiperList()
   ,
   methods: 
     // 3. 获取轮播图数据的方法
     async getSwiperList() 
       // 3.1 发起请求
       const  data: res  = await uni.$http.get('/api/public/v1/home/swiperdata')
       // 3.2 请求失败
     if (res.meta.status !== 200) return uni.$showMsg()
       // 3.3 请求成功,为 data 中的数据赋值
       this.swiperList = res.message
     ,
   ,
 

以上是关于uniapp项目中配置网络请求的主要内容,如果未能解决你的问题,请参考以下文章

uni-app网络请求封装

uniapp网络调试问题汇总

uniapp网络监测

uniapp请求+uView2.0请求封装

uniapp外包杯学习笔记day07 | 微信小程序轮播图分类导航楼层图的开发与实现

vue3+uniapp封装请求总是出错