正在阅读:如何使用微信小程序开发快递查询?使用方法介绍如何使用微信小程序开发快递查询?使用方法介绍

2017-12-27 12:22 出处:其他 作者:佚名 责任编辑:lishengtao

  今天小编和大家一起学习的是如何使用微信小程序开发快递查询?一定有许多朋友很是期待吧,下面就是详细的内容。

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

  第二步:准备

  我们先找一个快递的api接口,找一个快递查询的

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

  第三步:编码工作

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

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

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

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

  查询

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

  /**index.wxss**/

  input{border:1pxsolid#1AAD19;width:90%;height:20px;font-size:12px;padding:5px10px;}

  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

  //获取应用实例

  varapp=getApp()

  Page({

  data:{

  motto:'HelloWorld',

  userInfo:{},

  einputinfo:null,//输入框值

  expressInfo:null//快递信息

  },

  //事件处理函数

  bindViewTap:function(){

  wx.navigateTo({

  url:'../todos/todos'

  })

  },

  onLoad:function(){

  console.log('onLoad')

  varthat=this

  //调用应用实例的方法获取全局数据

  app.getUserInfo(function(userInfo){

  //更新数据

  that.setData({

  userInfo:userInfo

  })

  })

  },

  //快递输入框事件

  input:function(e){

  this.setData({einputinfo:e.detail.value});

  },

  //查询事件

  btnClick:function(){

  varthisexpress=this;

  app.getExpressInfo(this.data.einputinfo,function(data){

  console.log(data);

  thisexpress.setData({expressInfo:data})

  })

  }

  })

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

  //index.js

  //获取应用实例

  varapp=getApp()

  Page({

  data:{

  motto:'HelloWorld',

  userInfo:{},

  einputinfo:null,//输入框值

  expressInfo:null//快递信息

  },

  //事件处理函数

  bindViewTap:function(){

  wx.navigateTo({

  url:'../todos/todos'

  })

  },

  onLoad:function(){

  console.log('onLoad')

  varthat=this

  //调用应用实例的方法获取全局数据

  app.getUserInfo(function(userInfo){

  //更新数据

  that.setData({

  userInfo:userInfo

  })

  })

  },

  //快递输入框事件

  input:function(e){

  this.setData({einputinfo:e.detail.value});

  },

  //查询事件

  btnClick:function(){

  varthisexpress=this;

  app.getExpressInfo(this.data.einputinfo,function(data){

  console.log(data);

  thisexpress.setData({expressInfo:data})

  })

  }

  })

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

  /**index.wxss**/

  input{border:1pxsolid#1AAD19;width:90%;height:20px;font-size:12px;padding:5px10px;}

  button{margin-top:20px;}

  .expressinfo{font-size:12px;line-height:18px;padding:10px;text-align:left;}

  .expressinfoli{display:block}

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

关注我们

最新资讯离线随时看 聊天吐槽赢奖品