微信小程序——快递查询
前言
最近在学习微信小程序,一个简单的快递查询小程序却让人头疼不已,不知道用哪个快递查询api,不知道如何传递api参数,不知道事件如何监听···
现在将过程记录下来,供大家相互参考学习~
思维导图
目录
产品需求
前期准备
编写界面
逻辑实现
显示信息
Bug调试
源代码
产品需求
在文本框输入快递单号,点击查询,在下面显示快递信息。
最终效果预览:
前期准备
1.准备一个快递查询的API
推荐:apishop(https://www.apishop.net)
在这里推荐apishop的原因是,apishop里面提供快递查询接口只需要提供运单号,而像聚合数据、showapi、易源接口、阿里云等网站虽然也能提供快递查询接口,但是它们都需要同时提供运单号和公司编码才能进行数据请求。
进入apishop官网后,需要进行一系列的注册认证~
查看请求示例:
可以看到这里的请求参数只有apikey和expressNumber是必须的,而公司类型可以自动识别出来。
2.查看并保存你的API Key
在你注册认证完成之后,在控制台页面可以看到你的apikey:
3.准备一个真实的运单号
你可以从自己的历史快递消息中,复制保存好一个运单号码,以便于开发测试的时候使用。
编写界面
1.修改顶部导航文字
在app.json中修改如下:
"navigationBarTitleText": "快递查询"
2.添加一个输入框和一个按钮,并为它们绑定事件
<!--index.wxml-->
<input placeholder='请输入运单号' bindinput='input'></input>
<button type="primary" bindtap='btnClick'>查询</button>
3.修改输入框和按钮的样式
/**index.wxss**/
input {border: 1px solid green;width: 80%;padding: 5px;margin: 10px;
}
button {margin: 5px;
}
效果:
逻辑实现
1.编写getExpressInfo方法调用快递查询接口
- 在app.js中编写getExpressInfo方法,并且用微信提供的wx.request发起网络请求,调用我们之前申请的接口
- 设置两个变量,一个expressNumber为要查询的快递单号,一个cb为返回查找到的内容到data中的方法
//app.js
getExpressInfo: function (expressNumber,cb){wx.request({url: 'https://api.apishop.net/common/express/getExpressInfo?apiKey=你的apikey&expressNumber=' + expressNumber,data: {x: '',y: ''},header: {'apiKey': '你的apikey' },success(res) {cb(res.data)}})},
cb是指callback( )回调函数,回调函数就是一个参数,将这个函数作为参数传到另一个函数里面,当那个函数执行完之后,再执行传进去的这个函数。
2.在data中设置两个变量
//index.js
data: {motto: 'Hello World',userInfo: {},hasUserInfo: false,canIUse: wx.canIUse('button.open-type.getUserInfo'),expressNu:null,//用来保存输入的运单号expressInfo:null//用来保存查询到的快递信息},
3.编写输入框的事件
//index.js
input:function(e){this.setData({expressNu:e.detail.value})}
//setData()函数用于将数据从逻辑层发送到视图层,同时改变对应的this.data
4.编写按钮的事件
//index.js
getUserInfo: function(e) {console.log(e)app.globalData.userInfo = e.detail.userInfothis.setData({userInfo: e.detail.userInfo,hasUserInfo: true})}
显示信息
1.使用wx:for遍历数组并输出
2.使用scroll-view组件让信息滚动显示
<!--index.wxml-->
<scroll-view scroll-y style="height: 400px;"><view>{{expressInfo.result.expName}}</view><!--显示快递公司名称--><!--快递信息保存在expressInfo下的result中的list数组中,用for循环遍历显示出来--><view wx:for="{{expressInfo.result.list}}">{{item.status}} 【{{item.time}}<!--item表示当前项--></view>
</scroll-view>
Bug调试
出现错误提示:url不在以下 request 合法域名列表中
运行小程序时,会遇到错误信息:url不在以下 request 合法域名列表中
这是因为小程序微信公众平台设置小程序开发设置中服务器合法域名必须是https,而我们自己的url是http://开头的,
此时的处理方式为:工具—项目详情—勾选不校验安全域名、web-view 域名、TLS 版本以及 HTTPS 证书。
源代码
app.json:
{"pages": ["pages/index/index","pages/logs/logs"],"window": {"backgroundTextStyle": "light","navigationBarBackgroundColor": "#fff","navigationBarTitleText": "快递查询","navigationBarTextStyle": "black"},"sitemapLocation": "sitemap.json"
}
index.wxml:
<!--index.wxml-->
<view class="container"><input placeholder='请输入运单号' bindinput='input'></input><button type="primary" bindtap='btnClick'>查询</button><scroll-view scroll-y style="height: 400px;"><view>{{expressInfo.result.expName}}</view><view wx:for="{{expressInfo.result.list}}">{{item.status}} 【{{item.time}}</view></scroll-view>
</view>
index.wxss
/**index.wxss**/
input {border: 1px solid green;width: 80%;padding: 5px;margin: 10px;
}
button {margin: 5px;
}
index.js:
//index.js
//获取应用实例
const app = getApp()Page({data: {motto: 'Hello World',userInfo: {},hasUserInfo: false,canIUse: wx.canIUse('button.open-type.getUserInfo'),expressNu:null,expressInfo:null},//事件处理函数bindViewTap: function() {wx.navigateTo({url: '../logs/logs'})},onLoad: function () {if (app.globalData.userInfo) {this.setData({userInfo: app.globalData.userInfo,hasUserInfo: true})} else if (this.data.canIUse){// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回// 所以此处加入 callback 以防止这种情况app.userInfoReadyCallback = res => {this.setData({userInfo: res.userInfo,hasUserInfo: true})}} else {// 在没有 open-type=getUserInfo 版本的兼容处理wx.getUserInfo({success: res => {app.globalData.userInfo = res.userInfothis.setData({userInfo: res.userInfo,hasUserInfo: true})}})}},btnClick:function(){var thispage = this;//console.log(this.data.expressNu)app.getExpressInfo(this.data.expressNu,function(data){//console.log(data)thispage.setData({expressInfo:data})})},input:function(e){this.setData({expressNu:e.detail.value})},getUserInfo: function(e) {console.log(e)app.globalData.userInfo = e.detail.userInfothis.setData({userInfo: e.detail.userInfo,hasUserInfo: true})}
})
app.js:
//app.js
App({onLaunch: function () {// 展示本地存储能力var logs = wx.getStorageSync('logs') || []logs.unshift(Date.now())wx.setStorageSync('logs', logs)// 登录wx.login({success: res => {// 发送 res.code 到后台换取 openId, sessionKey, unionId}})// 获取用户信息wx.getSetting({success: res => {if (res.authSetting['scope.userInfo']) {// 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框wx.getUserInfo({success: res => {// 可以将 res 发送给后台解码出 unionIdthis.globalData.userInfo = res.userInfo// 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回// 所以此处加入 callback 以防止这种情况if (this.userInfoReadyCallback) {this.userInfoReadyCallback(res)}}})}}})},getExpressInfo: function (expressNumber,cb){wx.request({url: 'https://api.apishop.net/common/express/getExpressInfo?apiKey=你的apikey&expressNumber=' + expressNumber,data: {x: '',y: ''},header: {'apiKey': '你的apikey' },success(res) {cb(res.data)}})},globalData: {userInfo: null}
})
微信小程序——快递查询相关推荐
- 微信小程序 —— 快递查询Demo(入门)
源码地址及提醒: 1.seach.js中的wx.request所用URL需要用申请所得数据接口替换,数据接口申请地址:https://www.juhe.cn/docs/api/id/43 2.由于使用 ...
- 微信小程序--订单查询页面
微信小程序–订单查询页面 包含功能点: 订单查询 结构:order.wxml <tabs tabList="{{tabList}}" binditemChange=" ...
- 基于微信小程序公交查询系统设计与实现
[摘 要]随着互联网的技术的不断更新发展,人们生活节奏也在不断的加快,对于网络的依赖也越来越紧密,尤其是在等公交,经常会错过班次,但又不知道,下次班次几点发车,这样会导致乘客花掉大把时间在等待,如果可 ...
- 微信小程序 星座查询
微信小程序 星座查询 1.界面布局 1. .xml代码 <image class="anime_bg" src="/images/cartoon_2.jpg&quo ...
- 快速上手微信小程序-快递100
2007 年 1 月 9 日,乔布斯在旧金山莫斯科尼会展中心发布了首款 iPhone,而在十年后的 1 月 9 日,微信小程序正式上线.张小龙以这样的形式,向乔布斯致敬. 小程序在哪里? 小程序功能模 ...
- 微信小程序--火车票查询
写在最前面 微信小程序自九月份推出内测资格以来,经历了舆论热潮到现在看似冷清,但并不意味着大家不那么关注或者不关注了.我想不管是否有内测资格,只要是感兴趣的开发者已经进入潜心耕耘产品的阶段了,至少是静 ...
- 微信小程序火车票查询 直取12306数据
最终效果图: 样式丑哭了,我毕竟不是前端,宗旨就是练练手,体验微信小程序的开发,以最直接的方式获取12306数据查询火车票. 目录结构: search1是出发站列表,search2是目的站列表,命名没 ...
- 基于微信小程序菜谱查询app设计
设计一个基于微信小程菜单查询app,一共有2个身份包括用户和管理员!用户通过微信小程序打开app后可以查询最新上架的菜谱信息,查询和查看菜谱详情信息,收藏自己喜欢的菜谱,发布留言和查看新闻公告!管理员 ...
- 微信小程序天气查询功能--使用高德开放平台接口
写在前面: 最近做的一个小程序,加入了获得当前位置天气的功能.比对了网上几个所谓的免费接口,聚合和心知发现免费的有限...500次免费的额度确实不够用,500块一个月的也用不起. 后来,又发现腾讯和高 ...
最新文章
- 南韩开创AI训练 可自产深度学习数据集
- 数据测试常用的 Data Profiling 方法
- python spark 求解最大 最小 平均
- vue 使用fs_模仿vue-cli,手写一个脚手架
- 利用js实现 禁用浏览器后退| 去除上一个历史记录链接
- 赵雅智_Fragment生命周期
- 项目NABCD的分析
- 用例子来区分4种文法
- CentOS操作系统版本信息查看和隐藏
- CMap的使用(转)
- 聊聊React的路由React-Router、react-router-dom
- 面向对象的超级面试题,涉及封装多态继承等多方面考核,异常烧脑,90%的面试官必问题目,不会这个的,只是会搬砖的码农
- 【qt+opencv】实现人脸识别打卡系统2.0
- python百度关键词自动提交订单_Python+selenium刷百度关键词点击
- kali Linux的优点与缺点
- 【产品人卫朋】2022年产品人必备的13个设计类网站(1.0版)
- android访问win10共享文件夹,手机怎么用ES浏览器访问Win10共享文件教程
- vs2010安装失败(如下图)的解决方法
- C++播放音频mav文件和mp3文件
- 什么是C语言?到底难不难学?——新手问题篇