小程序开发-第二章第四节小程序http请求与请求本地json文件-全栈工程师之路-中级篇

简介: 小程序开发-第二章第四节小程序http请求与请求本地json文件-全栈工程师之路-中级篇

上一节课,我们已经基本完成了,首页的界面编写。

逻辑暂时不理会。

但是我们用于展示页面绑定的是我们本地的假数据。

接下来我们就来获取真正的数据来展示页面。

请跳过划线部分,我只是不想删除而已。


绑定假数据编写页面算是前段最早做的一件事情吧。

特别是在前后端同步开发,联合测试的时候。

服务端会先输出接口文档,然后前后端根据接口文档同步开发,最后联合测试。

这就需要前段本地编写大量的假数据。

如果我们每个页面的假数据的单独编写的话,后续和服务端联调,我们就需要更改大量的文件。

且修改完链接到服务器,然后又加了一个需求或者服务器挂了,这时候你要本地调试,就会变得很麻烦,你要把你修改的地方再改回来。

这样的操作繁琐而且容易出错。

这时候我们就可以思考一下,是不是有什么办法,构建一个本地的假数据服务。

这里只说一个我最常用的吧,使用http请求本地的json文件,来获取数据。

本地的json文件,根据接口文档创建同样的层级目录,联调的时候只要在请求地址的最前端加入服务器地址就可以了。

有两个缺点:

一、这样的请求方式,不支持携带参数的请求,就是不管你写的是什么条件,最终获得的都是本地的json文件,原样输出。

二、访问本地的文件需要些文件后缀名,如data/data.json.有些服务器请求地址是data/data。后续删除也是一个麻烦的问题。

根据上面的思路,我们要做几件事情。

1、获取接口文档

2、统一管理服务器地址

3、创建本地假数据文件

4、编写http请求本地json文件

5、修改服务器地址访问真正的服务器

6、调试修改。

wx.request不支持请求本地json(写了半天发现微信不支持,这才叫瞎比比),这部分就不讲了,直接讲真实数据了。


软件开发基本上就是这么一个流程,发现问题,归纳问题,提出解决方案,编写程序,最后测试验证方案准确。

1、首先我在很早的时候就说过了,我们这次使用豆瓣电影的公开API文档https://developers.douban.com/wiki/?title=api_v2

真是的请求地址是如https://api.douban.com/v2/movie/in_theaters?count=3(直接浏览器访问就能请求到数据哦!)

2、我们在util.js文件中,增加服务器的统一地址变量。

image.png

其实更好的做法是,编写一个url处理方法。这样如果后续需要统一的追加参数,或者其他的统一操作,可以直接在这里修改。

image.png

3、编写http请求。我们先请求正在上映。

image.png

在小程序中我们使用wx.request发送http请求。

我们在index.js中编写

image.png

url:请求地址,这里我们调用factory方法处理了

method:请求方式

header:有时候服务端要求带请求头

data:请求参数

success:成功回调

fail:失败回调

这里要注意的是要在头部引用util文件var util = require('../../utils/util.js');

这里我们在成功和失败的时候都打印了日志,所以运行程序打开控制台。

image.png

这个问题是微信为了数据安全,要在后台配置合法域名。后台配置在“设置”-“开发设置”中填写request合法域名。

由于我们没有自己的服务器,又只是在开发环境测试,所以我们可以使用以下方法访问非合法域名。

在开发工具左侧“项目”里面,勾选“开发环境不校验请求域名、TLS版本以及HTTPS证书”

image.png

刷新项目,还是查看控制台

image.png这里我们打印了从豆瓣获取的数据,控制台也明确声明了工具未验证。

4、回调函数中绑定数据

image.png

我们将服务器请求的数据展开,标记我们需要的数据,我们会发现有一些我们不需要的数据,

由于我们调用的是公共的API所以会有很多数据提供给其他用户的其他需求,

如果我们调用私有的API的时候,这种情况比较少,但是也不排斥服务器懒直接对一个大对象给你的。


你跟他说流量啥的,都说服不了他的“方便”。

所以我们这里写一个方法,把我们需要的数据取出来。

还有一点是因为我们最开始写这个页面的时候,是没有借口文档的,所以所有的变量名都是我们自己定义的。

但是拿到借口文档之后,建议根据接口文档,把变量名都改过来,对于后续的维护和调试有很大的好处。

image.png

修改index.wxml

image.png修改movielist模板

image.png修改moviecard模板里绑定的变量名

image.png运行程序

image.png

我们发现,中间这个电影的名字太长了,我们界面上不需要这么长,

所以我们在moviecard模板的样式文件里面加入强制不换行,超出省列号显示的属性。

image.png

(截图的时候少了一个width:200rpx;)

有些接口需要许可,所以我们先挑选标志,不需要许可的接口

Required Scope

movie_premium_r


同样的方法,我们编写获取即将上映和Top250

即将上映

Resources URI

/v2/movie/coming_soon

Top250

Resources URI

/v2/movie/top250


通过观察我们发现这几个接口数据格式相同。


所以我们统一修改一下请求方法。

image.png

在index中使用

image.png

运行效果

image.png

到此我们的数据基本就绑定正确了。

但是如上图中标记的还有好几个效果不是很理想。

这里我们在starts模板里面增加wx:if当分数为0是显示暂无评分

然后请求的时候传递自定义栏目标题。

image.png

修改一点点细节。不改也无所谓。这节课主要的内容是http请求。

细心的朋友会在控制台看到这样一条警告。这是因为我们多次调用setData函数。

image.png

那么预计下一节课我们就讲解怎么解决这个问题。


这节课的内容就到这里结束了。
感谢您的阅读。






目录
相关文章
|
10月前
|
JSON 中间件 Go
Go 网络编程:HTTP服务与客户端开发
Go 语言的 `net/http` 包功能强大,可快速构建高并发 HTTP 服务。本文从创建简单 HTTP 服务入手,逐步讲解请求与响应对象、URL 参数处理、自定义路由、JSON 接口、静态文件服务、中间件编写及 HTTPS 配置等内容。通过示例代码展示如何使用 `http.HandleFunc`、`http.ServeMux`、`http.Client` 等工具实现常见功能,帮助开发者掌握构建高效 Web 应用的核心技能。
476 61
|
12月前
|
Linux C语言 iOS开发
C语言结合AWTK开发HTTP接口访问界面
这样,我们就实现了在C语言中使用libcurl和AWTK来访问HTTP接口并在界面上显示结果。这只是一个基础的示例,你可以根据需要添加更多的功能和优化。例如,你可以添加错误处理机制、支持更多HTTP方法(如POST、PUT等)、优化用户界面等。
621 82
|
Rust 前端开发 API
Tauri 开发实践 — Tauri HTTP 请求开发
本文介绍了如何在 Tauri 中发起 HTTP 请求。首先通过安装 Tauri 生态中的工具包并配置 `tauri.conf.json` 文件来允许特定域名的 HTTP 通信。接着封装了一个简单的 HTTP 客户端类,并在页面中使用该客户端实现 GET 和 POST 请求。最后提供了完整的源码地址以供参考。此功能使得桌面应用能够与远程服务器进行交互,增强了应用的实用性。
1247 1
Tauri 开发实践 — Tauri HTTP 请求开发
|
10月前
|
C# 图形学 开发者
Unity开发中使用UnityWebRequest从HTTP服务器下载资源。
总之,UnityWebRequest就是游戏开发者手中的万能钓鱼竿,既可以获取文本数据,也能钓上图片资源,甚至是那声音的涟漪。使用UnityWebRequest的时候,你需要精心准备,比如确定URL、配置请求类型和头信息;发起请求;巧妙处理钓获的数据;还需要机智面对网络波澜,处理各种可能出现的错误。按照这样的过程,数据的钓取将会是一次既轻松愉快也效率高效的编程钓鱼之旅。
528 18
|
12月前
|
Python
使用Python实现multipart/form-data文件接收的http服务器
至此,使用Python实现一个可以接收 'multipart/form-data' 文件的HTTP服务器的步骤就讲解完毕了。希望通过我的讲解,你可以更好地理解其中的逻辑,另外,你也可以尝试在实际项目中运用这方面的知识。
544 69
|
11月前
|
JSON 安全 网络协议
HTTP/HTTPS协议(请求响应模型、状态码)
本文简要介绍了HTTP与HTTPS协议的基础知识。HTTP是一种无状态的超文本传输协议,基于TCP/IP,常用80端口,通过请求-响应模型实现客户端与服务器间的通信;HTTPS为HTTP的安全版本,基于SSL/TLS加密技术,使用443端口,确保数据传输的安全性。文中还详细描述了HTTP请求方法(如GET、POST)、请求与响应头字段、状态码分类及意义,并对比了两者在请求-响应模型中的安全性差异。
1008 20
|
9月前
|
存储 人工智能 Java
java之通过Http下载文件
本文介绍了使用Java实现通过文件链接下载文件到本地的方法,主要涉及URL、HttpURLConnection及输入输出流的操作。
633 0
|
XML JSON Linux
Reqable:跨平台HTTP开发与调试工具
Reqable是一款功能强大且易于使用的跨平台HTTP开发与调试工具,具有多平台支持、全面的HTTP请求构建与解析、请求历史记录和环境管理等功能。它简化了HTTP请求的构建、发送和响应分析过程,为开发者提供了极大的便利。通过Reqable,开发者可以更高效地进行HTTP开发和调试,提高工作效率和代码质量。
997 26
|
12月前
|
人工智能 网络协议 API
开发效率翻倍!Apipost这些协议调试秘籍,从HTTP到金融报文全搞定
Apipost是一款强大的API研发管理工具,支持多种协议与数据格式,包括HTTP(s)、WebSocket、SSE、gRPC、TCP及金融协议(如ISO 8583、FIX)。它内置国密算法库,提供HTTP文件秒传、全局参数配置等实用功能。在SSE调试中,可轻松处理AI模型流式响应;WebSocket与Socket.IO实现高效实时通信;GraphQL支持可视化Query编写;TCP模块解决金融报文编码难题;gRPC则具备服务反射与流式调试能力。Apipost不仅简化了多协议切换的复杂性,还自动生成文档,显著提升开发效率,让开发者专注于核心业务逻辑。
|
缓存 安全 数据处理
Objective-C开发:从HTTP请求到文件存储的实战
Objective-C开发:从HTTP请求到文件存储的实战