找回密码
 立即注册

扫一扫,访问微社区

查看: 7819|回复: 5

现学现卖的一个“快递查询“的小程序开发

  [复制链接]

76

主题

28

回帖

10万

金钱

管理员

积分
0

优秀版主

发表于 2017-1-13 17:22:49 | 显示全部楼层 |阅读模式
本帖最后由 cyk 于 2017-1-13 17:24 编辑

最近微信小程序是炒的如火如荼,各种热门, 正好赶上这个热潮,这几天先把小程序技术文档看了个遍,结合教程手写了一个案例。

今天写了一个快递查询的小demo,大致分为三步:产品需求,准备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;}

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

[/url]

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

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

[url=]
//设置一个发起网络请求的方法  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  }[url=][/url]

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

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

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

[url=][/url]
//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})    })  }})[url=][/url]

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

[url=][/url]
<!--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> [url=][/url]

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

/**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}

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

[url=http://www.wxapp-union.com/data/attachment/forum/201701/06/173223fw7817swv8yw7f8t.png][/url]




本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

0

主题

7

回帖

76

金钱

新人求带

积分
0
发表于 2017-1-15 20:43:19 | 显示全部楼层
厉害,能教教我吗?

0

主题

1

回帖

23

金钱

新人求带

积分
0
发表于 2017-3-2 17:05:03 | 显示全部楼层
啥也不说了,感谢楼主分享哇!

0

主题

28

回帖

160

金钱

新人求带

积分
0
发表于 2018-12-1 22:33:02 | 显示全部楼层
谢谢分享,好好学习

0

主题

3

回帖

16

金钱

新人求带

积分
0
发表于 2018-12-2 14:20:45 | 显示全部楼层
谢谢分享
回复

使用道具 举报

0

主题

408

回帖

600

金钱

新人求带

积分
0
发表于 2020-4-5 15:25:07 | 显示全部楼层
我有流量,寻求个人游戏开发者合作,有意者联系微,信,号j i m 2 0 1 8 0 6 8 8
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|微信小程序开发|教程|文档|资源汇总_即速论坛 ( 粤ICP备14097199号-1  

GMT+8, 2024-11-22 00:13 , Processed in 0.149506 second(s), 35 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表