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

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

相关文章

spring中的ImportSelector接口示例详解

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

MybatisPlus service接口功能介绍

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

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程

Python程序的文件头部声明小结

《Python程序的文件头部声明小结》在Python文件的顶部声明编码通常是必须的,尤其是在处理非ASCII字符时,下面就来介绍一下两种头部文件声明,具有一定的参考价值,感兴趣的可以了解一下... 目录一、# coding=utf-8二、#!/usr/bin/env python三、运行Python程序四、

Java中的Closeable接口及常见问题

《Java中的Closeable接口及常见问题》Closeable是Java中的一个标记接口,用于表示可以被关闭的对象,它定义了一个标准的方法来释放对象占用的系统资源,下面给大家介绍Java中的Clo... 目录1. Closeable接口概述2. 主要用途3. 实现类4. 使用方法5. 实现自定义Clos

java对接第三方接口的三种实现方式

《java对接第三方接口的三种实现方式》:本文主要介绍java对接第三方接口的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录HttpURLConnection调用方法CloseableHttpClient调用RestTemplate调用总结在日常工作

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

Java 的 Condition 接口与等待通知机制详解

《Java的Condition接口与等待通知机制详解》在Java并发编程里,实现线程间的协作与同步是极为关键的任务,本文将深入探究Condition接口及其背后的等待通知机制,感兴趣的朋友一起看... 目录一、引言二、Condition 接口概述2.1 基本概念2.2 与 Object 类等待通知方法的区别