小程序开发-第二章第四节小程序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

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


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






目录
相关文章
|
1月前
|
小程序 前端开发 Android开发
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
462 29
小程序微信分享功能如何开发?开放平台已绑定仍不能使用的问题?-优雅草卓伊凡
|
2月前
|
XML JSON API
如何在 Postman 中上传文件和 JSON 数据
如果你想在 Postman 中同时上传文件和 JSON 数据,本文将带你一步一步地了解整个过程,包括最佳实践和技巧,让你的工作更轻松。
|
2月前
|
监控 前端开发 小程序
陪练,代练,护航,代打小程序源码/前端UNIAPP-VUE2.0开发 后端Thinkphp6管理/具备家政服务的综合型平台
这款APP通过技术创新,将代练、家政、娱乐社交等场景融合,打造“全能型生活服务生态圈”。以代练为切入点,提供模块化代码支持快速搭建平台,结合智能匹配与技能审核机制,拓展家政服务和商业管理功能。技术架构具备高安全性和扩展性,支持多业务复用,如押金冻结、录屏监控等功能跨领域应用。商业模式多元,包括交易抽成、增值服务及广告联名,同时设计跨领域积分体系提升用户粘性,实现生态共生与B端赋能。
205 12
|
2月前
|
小程序 Java 关系型数据库
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。
|
2月前
|
人工智能 开发框架 小程序
工会成立100周年纪念,开发职工健身AI运动小程序、APP方案推荐
为庆祝中华全国总工会成立100周年,特推出基于AI技术的智能健身系统,以小程序和APP形式呈现,助力职工健康生活。方案包括:1) 小程序插件,支持多种运动识别,开箱即用;2) APP插件,提供更高精度的运动检测;3) 成熟的「AI乐运动」系统,支持赛事活动管理。这些方案满足不同需求,推动全民健身体验升级,彰显工会对职工健康的关怀。
|
2月前
|
人工智能 小程序 NoSQL
【一步步开发AI运动小程序】二十一、如何将AI运动项目配置持久化到后端?
本文介绍基于云智「Ai运动识别引擎」的运动配置持久化方案,旨在优化小程序或Uni APP中AI运动识别能力。通过将运动检测参数(如`Key`、`Name`、`TickMode`、`rules`或`samples`)持久化到后端,可避免因频繁调整运动参数而重新发布应用,提升用户体验。持久化数据结构支持规则和姿态样本存储,适用于关系数据库、文件或文档数据库(如MongoDB)。此外,云智还提供运动自动适配工具及「AI乐运动」产品,助力快速实现AI体育、全民健身等场景。
|
2月前
|
小程序 关系型数据库 Java
weixin168“返家乡”高校暑期社会实践微信小程序设计与开发ssm(文档+源码)_kaic
本文探讨高校暑期社会实践微信小程序的开发与应用,旨在通过信息化手段提升活动管理效率。借助微信小程序技术、SSM框架及MySQL数据库,实现信息共享、流程规范和操作便捷。系统涵盖需求分析、可行性研究、设计实现等环节,确保技术可行、操作简便且经济合理。最终,该小程序可优化活动发布、学生信息管理和心得交流等功能,降低管理成本并提高工作效率。
|
3月前
|
人工智能 编解码 小程序
【一步步开发AI运动小程序】二十、AI运动小程序如何适配相机全屏模式?
本文探讨了小程序`camera`组件在全屏模式下的适配问题及其解决方案。由于`camera`组件存在预览图像裁切特性,可能导致入镜检测与预览不一致、骨骼图与人体不重合等问题。通过分析其裁剪逻辑(长边按比缩放,短边居中裁切),我们提供了计算裁剪比例和留白的适配方法,并优化了插件特性以支持全屏应用。同时,文章还讨论了全屏模式可能带来的副作用,如人体可视区域变小、检测范围变化及抽帧帧率下降等,并给出了改进建议。该方案适用于云上赛事、健身锻炼、AI体测、AR互动等场景,助力提升用户体验和UI布局合理性。
|
5月前
|
移动开发 小程序
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
157 0
|
7月前
|
小程序 前端开发 JavaScript
在线课堂+工具组件小程序uniapp移动端源码
在线课堂+工具组件小程序uniapp移动端源码
156 0
在线课堂+工具组件小程序uniapp移动端源码