黑马优购小程序之接口优化

2024-05-12 10:48

本文主要是介绍黑马优购小程序之接口优化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

      • 1.1 提取接口公共路径
      • 1.2 使用es7的async
        • 1.2.1 开启增强编译
        • 1.2.2 修改代码
      • 1.3 简化返回值
      • 1.4 小结

1.1 提取接口公共路径

在前面的开发中,网络请求中,url是这么写的:

url: "https://api-hmugo-web.itheima.net/api/public/v1/categories"

如果每个接口都这样的话,就有些繁琐了。在项目中,url公共路径可以提取出来,各业务接口只写配置各自的路径就好了。

修改request/index.js文件,在其中定义baseUrl,并拼接新的请求url,代码如下:

export const request = (params) => {return new Promise((resolve, reject) => {const baseUrl = "https://api-hmugo-web.itheima.net/api/public/v1";wx.request({...params,url: baseUrl + params.url,success: (result) => {resolve(result);},fail: (error) => {reject(error);}});})
}

将业务请求url修改,以category为例:

/* 加载分类数据*/
getCates() {request({url: "/categories"}).then(result => {this.Cates = result.data.message;// 本地存储数据wx.setStorageSync("cates", { time: Date.now(), data: this.Cates });this.updateUI();})
},

这样就完成了接口公共路径的抽取优化。

1.2 使用es7的async

接下来使用asyncawait简化请求代码。

1.2.1 开启增强编译

在这里插入图片描述

1.2.2 修改代码

此处以category/index接口为例,代码修改为:

/* 
加载分类数据
*/
async getCates() {const res = await request({ url: "/categories" });this.Cates = res.data.message;// 本地存储数据wx.setStorageSync("cates", { time: Date.now(), data: this.Cates });this.updateUI();
}

是不是清爽很多~

1.3 简化返回值

每个接口都需要this.Cates = res.data.message做解析,这里做下简化操作,将message直接传入各接口调用处。

修改request/index.js,在success中将message返回,代码如下:

export const request = (params) => {return new Promise((resolve, reject) => {const baseUrl = "https://api-hmugo-web.itheima.net/api/public/v1";wx.request({...params,url: baseUrl + params.url,success: (result) => {resolve(result.data.message);},fail: (error) => {reject(error);}});})
}

修改各接口解析方式,此处以category/index.js为例:

/* 加载分类数据
*/
async getCates() {const res = await request({ url: "/categories" });this.Cates = res;// 本地存储数据wx.setStorageSync("cates", { time: Date.now(), data: this.Cates });this.updateUI();// request({//   url: "/categories"// }).then(result => {//   this.Cates = result.data.message;//   // 本地存储数据//   wx.setStorageSync("cates", { time: Date.now(), data: this.Cates });//   this.updateUI();// })
},

如上,完成接口返回值解析的简化。

1.4 小结

本节主要功能知识点如下:

  • 提取接口公共路径
  • 使用es7asyncawait简化请求
  • 简化接口返回值解析

这篇关于黑马优购小程序之接口优化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/982419

相关文章

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

SpringBoot+Redis防止接口重复提交问题

《SpringBoot+Redis防止接口重复提交问题》:本文主要介绍SpringBoot+Redis防止接口重复提交问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录前言实现思路代码示例测试总结前言在项目的使用使用过程中,经常会出现某些操作在短时间内频繁提交。例

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP