uniapp项目实战系列(4):服务的异步请求,请求服务的二次封装


✨ 原创不易,还希望各位大佬支持一下!

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!


1.介绍

本文主要是轮播图数据的请求与渲染和网络请求的封装

在本文章中学会在服务的异步请求,请求服务的二次封装

2.功能搭建流程

2.1启动后端服务

需要注意的是后端服务的cmd不能关闭哦,关闭了就本地的后端服务就停止了

2.2请求获取轮播图数据

2.2.1整体的请求

下图为:未封装网络请求以及不进行异步操作的整个页面请求

在data中设置变量存放数据

在onLoad(页面加载时)设置获取轮播图数据的方法

在methods中编写请求轮播图数据的方法

uni.request:发起网络请求(文档地址

uni.showToast:显示消息提示框(文档地址
tips:
1.axios只有浏览器支持,为了用多端要用uni提供的请求了
2.uniapp App端没有浏览器对象,不支持axios,请用官方的API:uni.request() ,打开调试能用是因为调试的时候JS是在电脑运行的,而电脑带有浏览器端对象
3.localhost 的 IP 地址是 127.0.0.1,所以说http://127.0.0.1:8082=http://localhost:8082
4.设计稿是按照375px*2=750px,是2倍图,750rpx相当于设计稿的全部宽度,1px=2rpx

2.2.3网络请求后立即回调(可以用于需要同步,一个接一个的调用)

这个函数中,getSwipers()使用了标准的回调方式来处理异步请求。当uni.request()发起网络请求后,该函数会立即返回,然后在请求成功或失败后的回调函数中执行相应的逻辑。这种方式在早期的JavaScript中非常常见,但随着异步处理的需求越来越复杂,这种方式往往会导致代码变得难以管理和理解,因为它涉及到回调函数的嵌套和"回调地狱"等问题。

2.2.3异步async/awit网络请求

这个函数中,getSwipers()使用了ES6引入的async/await语法来处理异步请求。这种方式使得异步代码看起来更像同步代码,使得代码更容易理解和维护。

2.3详细介绍es6的语法:aysnc/awit(了解可跳过)

在JavaScript中,异步调用是一种在执行过程中暂停当前执行,等待某个操作完成后继续执行的方式。这种机制可以避免阻塞主线程,提高程序的性能。

在JavaScript中,常见的异步方式有回调函数、Promise、async/await等。其中,async/await是ES2017引入的一种基于Promise的异步方式,它更加简洁、易于理解和使用。

2.3.1.async/await的语法

async表示函数是异步的,await表示在函数内部等待某个异步操作完成。

示例代码:

javascript 复制代码
async function asyncFunc() {  
  const result = await asyncOperation();  
  console.log(result);  
}

在上面的代码中,asyncFunc是一个异步函数,它内部调用了另一个异步函数asyncOperation,并使用await等待其完成。当await的表达式返回结果后,asyncFunc继续执行后续代码。

2.3.2.async/await的用法

async/await是基于Promise实现的,因此Promise的所有操作都可以使用async/await进行异步操作。

示例代码:

javascript 复制代码
async function asyncFunc() {  
  try {  
    const result = await promise(); // 等待promise完成并返回结果  
    console.log(result);  
  } catch (error) {  
    console.error(error); // 处理promise抛出的错误  
  }  
}

在上面的代码中,我们使用了try...catch结构来处理Promise可能抛出的错误。在try块中使用await等待Promise完成,并在需要时处理返回的结果。如果Promise抛出错误,catch块会捕获并处理该错误。

2.3.3.async/await的原理

async/await是通过将Promise对象转换为生成器实现的。具体来说,当一个函数被声明为async时,JavaScript会将该函数转换为生成器函数,并在函数内部使用Promise对象进行异步操作。当await表达式等待Promise完成时,JavaScript会暂停当前生成器函数的执行,等待Promise完成并返回结果后继续执行生成器函数。这种机制使得异步操作更加简洁、易于理解和使用。

2.3.4.async/await的注意事项

只能在async函数内部使用await,否则会抛出错误。

await的表达式必须是Promise对象,否则会直接返回该表达式的值。

使用await时必须用try...catch结构处理Promise可能抛出的错误。

如果一个async函数没有return语句或者return了一个未经await的Promise对象,该函数将返回一个Promise对象,并且该Promise将在函数结束时resolve为undefined。

2.4uni.request网络请求的二次封装和全局挂载

2.4.1编写api.js

这段代码是用于创建HTTP请求的JavaScript函数。它使用了ES6的模块导出和箭头函数,并且使用了uni.request函数来发送请求。这是一个基于Promise的异步函数,它返回一个Promise对象。

1.const BASE_URL = 'http://127.0.0.1:8082':定义了一个常量 BASE_URL,它是一个基础的URL,这个URL会作为所有请求的起点。

2.export const myRequest = (options) => { ... }:定义了一个名为 myRequest 的函数,并将它导出。这个函数接收一个对象 options 作为参数,该对象应该包含 url、method 和 data 属性。

3.return new Promise((resolve, reject) => { ... }):在函数内部,创建了一个新的Promise对象,并返回它。Promise是一个用于处理异步操作的JavaScript对象。resolve 和 reject 是Promise对象的两个回调函数,当Promise的状态从pending变为fulfilled时,resolve 函数会被调用;当Promise的状态从pending变为rejected时,reject 函数会被调用。

4.uni.request({ ... }):使用 uni.request 函数发送一个HTTP请求。这个函数应该是一个提供异步请求功能的库或者API的一部分。它接收一个包含多个属性的对象作为参数,包括请求的URL、请求的方法(默认为GET)、请求的数据等。

5.url: BASE_URL + options.url,:拼接基础URL和请求的URL,得到完整的请求URL。

6.method: options.method || 'GET', data: options.data || {}:如果 options 对象有 method 和 data 属性,则使用这些属性的值;否则,使用默认值 'GET' 和一个空对象。

7.success: (res) => { ... }, fail: (err) => { ... }:这两个属性是 uni.request 的回调函数。如果请求成功,会执行 success 回调;如果请求失败,会执行 fail 回调。

8.if (res.data.status !== 0) { ... }:在 success 回调中,检查响应的数据中的状态是否为0。如果状态不为0,表示获取数据失败,显示一个提示信息,并拒绝Promise。

9.resolve(res):如果获取数据成功,那么就通过 resolve 回调将响应的结果返回,使得Promise的状态变为fulfilled。

uni.showToast({ ... }):这是一个自定义的函数,它可能用于在前端展示一个提示信息。

10.reject(err):如果请求失败,那么就通过 reject 回调将错误信息返回,使得Promise的状态变为rejected。

2.4.2在mian.js中进行导入和全局挂载

这段代码是用于在 Vue.js 中引入并设置一个全局的函数 m y R e q u e s t 。 myRequest。 myRequest。myRequest 函数在后续的 Vue.js 组件中可以直接调用。

1.import {myRequest} from 'uni/api.js':从 'uni/api.js' 文件中引入 myRequest 函数。

2.Vue.prototype. m y R e q u e s t = m y R e q u e s t :将 m y R e q u e s t 函数赋值给 V u e 的原型对象。这意味着在所有的 V u e 组件中,都可以通过 t h i s . myRequest = myRequest:将 myRequest 函数赋值给 Vue 的原型对象。这意味着在所有的 Vue 组件中,都可以通过 this. myRequest=myRequest:将myRequest函数赋值给Vue的原型对象。这意味着在所有的Vue组件中,都可以通过this.myRequest 来调用这个函数。

2.4.3在请求轮播图数据中使用封装后的uni.request

2.5利用获取到的数据渲染到页面上

3.完整代码

3.1.api.js:

javascript 复制代码
const BASE_URL = 'http://127.0.0.1:8082'
export const myRequest = (options) => {
  return new Promise((resolve, reject) => {
    uni.request({
      url: BASE_URL + options.url,
      method: options.method || 'GET',
      data: options.data || {},
      success: (res) => {
        if (res.data.status !== 0) {
          return uni.showToast({
            title: '获取数据失败'
          })
        }
        resolve(res)
      },
      fail: (err) => {
        uni.showToast({
          title: '请求接口失败'
        })
        reject(err)
      }
    })
  })
}

这段代码是使用 JavaScript 编写的,并使用了一个叫做 uni 的库(通常在微信小程序等环境中使用)。它定义了一个名为 myRequest 的函数,该函数用于向指定的 URL 发送 HTTP 请求。

这个函数接收一个参数 options,该参数是一个对象,包含以下属性:

  • url: 请求的 URL。它将被添加到 BASE_URLhttp://127.0.0.1:8082)上。
  • method: 请求的 HTTP 方法,默认为 GET。
  • data: 要发送的数据,默认为空对象。
    函数返回一个 Promise,该 Promise 在请求成功时解析为响应,在请求失败时被拒绝。
    以下是函数的具体操作:
  1. uni.request 是一个函数,用于发送 HTTP 请求。它接收一个包含请求信息的对象作为参数。
  2. success 回调中,如果响应数据的 status 属性不等于 0,那么会显示一个错误提示('获取数据失败')。否则,将解析 Promise,并将响应作为结果返回。
  3. fail 回调中,无论请求是否成功,都会显示一个错误提示('请求接口失败'),并将错误拒绝到 Promise 中。

总的来说,这个函数提供了一种异步的方式去发送 HTTP 请求,并且对请求的成功和失败进行了基本的错误处理。

3.2main.js:

javascript 复制代码
import {myRequest} from 'uni/api.js'
Vue.prototype.$myRequest = myRequest

这段代码是用于在 Vue.js 中引入并暴露 myRequest 函数的。

具体来说,它做了以下几件事:

  1. import {myRequest} from 'uni/api.js':这行代码从 'uni/api.js' 文件中导入 myRequest 函数。这个文件可能包含了一些在 'uni' 环境下使用的 API,例如在微信小程序中。
  2. Vue.prototype.$myRequest = myRequest:这行代码将 myRequest 函数添加到 Vue 的原型上,使得在任何 Vue 实例中都可以通过 this.$myRequest 来访问这个函数。这是一种常见的在 Vue.js 中添加全局函数或属性的方式。
    所以,现在你可以在任何 Vue 组件中使用 this.$myRequest 来调用 myRequest 函数,进行你的 HTTP 请求。

3.3index.vue:

javascript 复制代码
<template>
  <view>
    <!-- 轮播图区域 -->
    <swiper :autoplay='true' :circular="true" >
      <swiper-item v-for="item in swipers" :key="item.id">
        <image :src="item.img"></image>
      </swiper-item>
    </swiper>
  </view>
</template>

<script>
  export default {
    data() {
      return {
        swipers: [], //轮播图的数据
      }
    },
    onLoad() {
      this.getSwipers() //页面加载时获取轮播图的数据
    },
    methods: {
      //封装时异步获取数据
      async getSwipers() {
        const res = await this.$myRequest({
          url: '/api/getlunbo'
        })
        this.swipers = res.data.message
      },
    }
  }
</script>

<style lang="scss" scoped>
  swiper {
    height: 200rpx;
    image {
      width: 100%;
      height: 100%;
    }
  }
</style>

这是一个使用 Vue.js 构建的组件,该组件用于在页面上展示一个轮播图。

以下是代码的详细解释:

  1. <template> 部分,我们有一个 swiper 组件,这是一个轮播图组件。:autoplay='true' 表示轮播图将自动播放,:circular="true" 表示轮播图是循环播放的。
  2. 在每个 swiper-item 中,我们用 v-for 指令循环渲染 swipers 数组中的每个元素。每个元素都是一个轮播图项,其图片通过 :src="item.img" 绑定。
  3. <script> 部分,我们定义了一个 Vue 组件。这个组件有一个 data 函数,它返回一个对象,其中包含 swipers 数据。这个数组用来存储轮播图的数据。
  4. onLoad() 是一个生命周期钩子,当组件加载完成时,它将调用 getSwipers() 方法获取轮播图的数据。
  5. getSwipers() 方法使用 this.$myRequest() 发送一个 HTTP 请求到 '/api/getlunbo' URL 来获取轮播图的数据。获取到的数据被赋值给 swipers
  6. 最后,在 <style> 部分,我们为 swiper 和其中的 image 元素定义了一些样式。轮播图的高度被设置为200rpx(可能是像素或者其他单位),图片的宽度和高度都被设置为100%,使得图片能完全填充其父元素。

总的来说,这是一个简单的轮播图组件,它通过异步获取数据并动态渲染轮播图项。

相关推荐
前端大卫7 分钟前
Vue3 + Element-Plus 自定义虚拟表格滚动实现方案【附源码】
前端
却尘23 分钟前
Next.js 请求最佳实践 - vercel 2026一月发布指南
前端·react.js·next.js
ccnocare24 分钟前
浅浅看一下设计模式
前端
Lee川27 分钟前
🎬 从标签到屏幕:揭秘现代网页构建与适配之道
前端·面试
Ticnix1 小时前
ECharts初始化、销毁、resize 适配组件封装(含完整封装代码)
前端·echarts
纯爱掌门人1 小时前
终焉轮回里,藏着 AI 与人类的答案
前端·人工智能·aigc
twl1 小时前
OpenClaw 深度技术解析
前端
崔庆才丨静觅1 小时前
比官方便宜一半以上!Grok API 申请及使用
前端
星光不问赶路人1 小时前
vue3使用jsx语法详解
前端·vue.js
天蓝色的鱼鱼1 小时前
shadcn/ui,给你一个真正可控的UI组件库
前端