微信小程序 开发之快递查询功能的实现

发布时间 - 2026-01-10 22:24:18    点击率:

微信小程序 快递查询功能:

产品需求,

准备api,

代码编写。 

第一步:产品需求,我们需要实现如下图的一个功能,在文本框输入快递单号,点击查询,下面出来我们需要的快递信息

第二步:准备

我们先找一个快递的api接口,通过http://apistore.baidu.com/我们可以看到很多的api,我们找一个快递查询的

 我们可以看到有接口地址,和一些参数。做好这个准备接下来就开始编码工作了………… 

第三步:编码工作

我们新建一个Express的文件,然后默认文件准备齐全

我们现在app.js中把我们的头部导航改为一个绿色的背景色

在index.json中设置导航的名称:“快递查询”

在index.wxml中,把默认的代码删掉,放上我们的一个文本输入框,一个查询按钮

<!--index.wxml-->
<view class="container">
  <input placeholder="请输入快递单号" bindinput="input" />
  <button type="primary" bindtap="btnClick"> 查询 </button> 
</view>

接下来我们需要给文本框和按钮加上一个样式:在index.wxss中设置

/**index.wxss**/
 input{border:1px solid #1AAD19; width:90%; height:20px; font-size:12px; padding:5px 10px;}
 button{margin-top:20px;}

到现在为止我们的布局就做好了如图:

 

  接下来我们需要去调用我们事先准备好的api快递查询接口了,我们首先需要在app.js中设置一个网络请求的方法getExpressInfo里面设置两个参数一个快递参数,一个返回的方法。

利用文档给我们提供的wx.request发起网络请求url:地址路径,里面有几个参数muti=0返回多行完整的数据,order=desc按时间由新到旧排列,com快递的名称(快递公司的名称),nu快递单号,header:请求的参数apikey的值为我们自己百度账号的apikey(可以登录自己的百度账号,在个人中心中查看)

//设置一个发起网络请求的方法
 getExpressInfo:function(nu,cb){
  wx.request({
   url: 'http://apis.baidu.com/kuaidicom/express_api/express_api?muti=0&order=desc&com=zhongtong&nu='+nu, 
   data: {
    x: '' ,
    y: ''
   },
   header: {
     'apikey': '247d486b40d7c8da473a9a794f900508'
   },
   success: function(res) {
    //console.log(res.data)
    cb(res.data);
   }
  })
 },
 globalData:{
  userInfo:null
 }

有了这样的请求方法,接下来就需要给我们的查询按钮添加一个点击的事件:bindtap="btnClick",在index.js中添加查询事件,通过app来调用实现写好的请求方法getExpressInfo,在此之前我们需要先获取一下文本框内输入的快递单号,

给文本框绑定一个bindinput事件,

 获取输入的快递单号。在data:对象中定义两个变量一个输入框的值,一个要显示的快递信息。

//index.js
//获取应用实例
var app = getApp()
Page({
 data: {
  motto: 'Hello World',
  userInfo: {}, 
  einputinfo:null,//输入框值
  expressInfo:null //快递信息
 },
 //事件处理函数
 bindViewTap: function() {
  wx.navigateTo({
   url: '../todos/todos'
  })
 },
 onLoad: function () {
  console.log('onLoad')
  var that = this
  //调用应用实例的方法获取全局数据
  app.getUserInfo(function(userInfo){
   //更新数据
   that.setData({
    userInfo:userInfo
   })
  })
 },
 //快递输入框事件
 input:function(e){
   this.setData({einputinfo:e.detail.value});
 },
 //查询事件
 btnClick:function(){ 
  var thisexpress=this; 
  app.getExpressInfo(this.data.einputinfo,function(data){
    console.log(data);
    thisexpress.setData({expressInfo:data})
  })
 }
})

最后我们需要在index.wxml中把查询出来的快递信息显示出来了,利用vx:for来循环数组。

<!--index.wxml-->
<view class="container">
  <input placeholder="请输入快递单号" bindinput="input" />
  <button type="primary" bindtap="btnClick"> 查询 </button> 
</view>
<view class="expressinfo" wx:for="{{expressInfo.data}}">
  <ul>
   <li>{{item.context}}</li>
   <li>{{item.time}}</li> 
  </ul> 
</view> 

 最后一步设置下显示出来的快递信息的样式:

/**index.wxss**/
 input{border:1px solid #1AAD19; width:90%; height:20px; font-size:12px; padding:5px 10px;}
 button{margin-top:20px;}
 .expressinfo{font-size:12px; line-height: 18px;padding:10px; text-align:left;} 
 .expressinfo li{display:block}

   到这里我们的整个查询就完成了……

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# 微信小程序  # 快递查询功能  # 微信小程序实现快递查询  # Python一键生成核酸检测日历的操作代码  # 利用Python制作简易的核酸检测日历  # 微信小程序云开发实现数据添加、查询和分页  # 使用微信小程序制作核酸检测点查询工具  # 文本框  # 输入框  # 给我们  # 请输入  # 可以看到  # 中把  # 自己的  # 应用实例  # 好了  # 在此  # 希望能  # 有几个  # 我们现在  # 如图  # 找一个  # 谢谢大家  # 第二步  # 绑定  # 就做  # 写好 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  如何自定义建站之星网站的导航菜单样式?  Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法  如何用低价快速搭建高质量网站?  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  bing浏览器学术搜索入口_bing学术文献检索地址  微信小程序 scroll-view组件实现列表页实例代码  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  Laravel怎么导出Excel文件_Laravel Excel插件使用教程  Claude怎样写结构化提示词_Claude结构化提示词写法【教程】  如何实现javascript表单验证_正则表达式有哪些实用技巧  Laravel API资源类怎么用_Laravel API Resource数据转换  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  Android使用GridView实现日历的简单功能  Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】  如何在局域网内绑定自建网站域名?  重庆市网站制作公司,重庆招聘网站哪个好?  Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言  ,交易猫的商品怎么发布到网站上去?  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  如何在宝塔面板中修改默认建站目录?  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  网站图片在线制作软件,怎么在图片上做链接?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  大连 网站制作,大连天途有线官网?  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  如何在Windows 2008云服务器安全搭建网站?  Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境  Laravel如何自定义分页视图?(Pagination示例)  如何在万网自助建站平台快速创建网站?  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  如何用搬瓦工VPS快速搭建个人网站?  Laravel storage目录权限问题_Laravel文件写入权限设置  如何挑选最适合建站的高性能VPS主机?  如何快速搭建二级域名独立网站?  Android Socket接口实现即时通讯实例代码  如何在阿里云虚拟主机上快速搭建个人网站?  Laravel如何使用Blade组件和插槽?(Component代码示例)  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  Laravel中的Facade(门面)到底是什么原理  公司门户网站制作流程,华为官网怎么做?  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  详解jQuery中的事件  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?