微信小程序学习——快递信息查询

前言

根据微信公众平台提供的官方文档小程序注册开发者工具的使用,可以注册微信公众平台,快速创建项目。文档很详细,在此就略过项目创建部分啦~

刚入门小程序,本项目是学习阶段写的小demo。GitHub项目地址

小程序的功能是:输入快递公司和单号,查询物流信息。涉及到一些小程序提供的表单组件,主要是为了学习网络请求接口的使用。
最终效果如下:查询主页面和查询结果详情页

主页面

详情页

目录结构

采用开发者工具提供的“建立普通快速启动模板”新建项目。

  • index为输入查询信息的主页面
  • detail为显示查询结果详情页
目录结构

一、 查询主页面

包括快递公司选择、快递单号和查询三部分

主页面未输入信息时

主页面输入信息时

1.快递公司选择

快递公司选择框

快递公司完成

使用微信小程序-表单组件-picker,实现从底部弹起的滚动选择器,选择不同快递公司。

参考资料:微信小程序官方文档picker介绍
结构(index.wxml)
<!--index.wxml-->
  <view class="company">
    <view class="title">快递公司:</view>
    <picker bindchange="bindPickerChange" value="{{index}}" range="{{array}}" range-key="name">
      <view class="picker" style="line-height: 50px;height: 50px;background: #fff;padding-left: 20px;font-size:18px;">
       当前选择:{{array[index]['name']}}
      </view>
    </picker>
  </view>
  • picker的range属性指定数组array(该数组为快递公司信息,在index.js中定义)
  • 当 range 是一个 Object Array 时,通过picker的range-key属性,指定 Object 中 key 的值作为选择器显示内容(在本例中name用于存储快递公司名字,在index.js中定义)
  • value属性中index无需在index.js中定义,表示选择了range对应项的第几个,也就是range指定数组的下标(从0开始)
  • bindchange用于绑定事件,bindPickerChange为事件处理函数,在index.js中定义
js(index.js)
//index.js

data: {
    array: [
      {
        'id':'yunda',
        'name':'韵达'
      },
      {
        'id':'shentong',
        'name':'申通'
      },
      {
        'id':'ems',
        'name':'EMS'
      },
      {
        'id':'shunfeng',
        'name':'顺丰'
      },
      {
        'id':'zhongtong',
        'name':'中通'
      }
    ],
    compangy_id:''
},
// 事件处理函数:公司选择
bindPickerChange: function(e) {
    //获取当前用户选择项,对应数组下标
    const val = e.detail.value;
    this.setData({
      index: val,
      compangy_id:this.data.array[val]['id']
    });
},
  • data中注册结构中用到的数据,快递公司信息数组array,定义compangy_id
  • bindPickerChange事件处理函数通过setData更新数据,包括当前用户选择项的对应数组下标index,compangy_id存储该项对应array中的id字段。(这个信息用于查询接口使用,在查询部分再详细说明)

2.快递单号

单号输入数字键盘

使用微信小程序-表单组件-input,用于输入快递单号。

参考资料:微信小程序官方文档input介绍
结构(index.wxml)
<!--index.wxml-->
  <view class="caseid">
    <view class="title">快递单号:</view>
    <input type="number" placeholder="请输入快递单号" bindinput="bindKeyInput" style="line-height: 50px;height: 50px;background: #fff;padding-left: 20px;font-size:18px;"/>
  </view>
  • type属性定义为number,可以空时显示数字输入键盘
  • bindKeyInput事件处理函数用于获取用户输入的单号,在index.js中定义
js(index.js)
  // 输入单号
  bindKeyInput: function (e) {
    this.setData({
      inputValue: e.detail.value
    })
  },

inputVaue同样需要在data中注册(与存储快递公司用到变量compangy_id类似),用该变量存储用户输入的表单信息

3.查询按钮

使用微信小程序-表单组件-button。

参考资料:微信小程序官方文档button介绍
结构(index.wxml)
<button type="primary" size="{{primarySize}}"
        bindtap="bindquery" style="margin-top:20px;"> 查询 </button>
  • type="primary"用于定义按钮样式类型,组件提供几种样式可供选择
  • size用于定义按钮大小,有效值为default和mini,默认为default
  • bindquery绑定查询事件
js(index.js)
  // 点击查询
  bindquery:function (e) {
    var data={
      'type':this.data.compangy_id,
      'postid':this.data.inputValue
    };
    wx.navigateTo({
      url: '../../pages/detail/detail?type='+data.type+'&postid='+data.postid
    })
  }

这里用到了一个公开的物流接口:

http://www.kuaidi100.com/query?type=快递公司代号&postid=快递单号

ps 快递公司代号:

申通=”shentong” EMS=”ems” 顺丰=”shunfeng” 圆通=”yuantong” 中通=”zhongtong” 韵达=”yunda” 天天=”tiantian” 汇通=”huitongkuaidi” 全峰=”quanfengkuaidi” 德邦=”debangwuliu” 宅急送=”zhaijisong”

参考资料: 各种JSON API免费接口
  • 通过上述快递公司和快递单号部分,可以获取接口需要的type和postid
  • wx.navigateTo是官方提供的API,保留当前页面,跳转到应用内的某个页面,使用wx.navigateBack可以返回到原页面。这里用于跳转到快递信息展示详情页detail,并将查询快递信息所需的参数传递到详情页。
参考资料: 微信小程序wx.navigateTo的API文档

二、 快递信息详情页

查询成功和失败时效果如下:

查询成功详情页

查询失败详情页
结构(detail.wxml)
<!--detail.wxml-->
<view class="container">
    <!--快递信息模板 begin-->
        <template name="items">
            <view class="row">
                <view class="time">
                    {{time}}
                </view>
                <view class="icon"></view>
                <view class="infos">
                    {{context}}
                </view>
            </view>
        </template>
    <!--快递信息模板 end-->
    <!--查询成功时 begin-->
        <view wx:if="{{haslist}}">
            <!--循环输出列表 begin-->
            <view class="mainline"></view>
            <block wx:for="{{list}}" wx:key="*this" class="scroll-view-item bc_green">
              <template is="items" data="{{...item}}" />
            </block>
            <!--循环输出列表 end-->
        </view>
    <!--查询成功时 end-->
    <!--查询失败时-->
    <view wx:else style="padding: 20px;">{{errmsg}}</view>
</view>
  • 快递信息模板,为一条快递信息的模板,包括时间和快递详情
  • wx:if和wx:for控制循环输出信息
  • 其中在列表循环是,如不提供 wx:key,会报一个 warning, 如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。详细使用见如下参考资料的wx:for
参考资料:

微信小程序官方文档列表渲染wx:for

微信小程序官方文档条件渲染wx:if

js(detail.js)
  data: {
    list:[],
    haslist:false,
    errmsg:''
  },
  //事件处理函数
  onLoad:function (options) {
    var that = this;
    wx.request( {
      url: 'https://www.kuaidi100.com/query',
      data: options,
      header: {
        'Content-Type': 'application/json'
      },
      success: function( res ) {
        // console.log( res.data );
        var msg=res.data.message;
        var data=res.data.data;
        if(msg==="ok"){
            that.setData({
              list: data,
              haslist:true
            });
            // console.log(that.data.list);
        }else{
            that.setData({
                errmsg:'请正确输入快递公司和单号'
            });
        }
      }
    })
  }
  • data中list用于存储快递信息数据,haslist用于结构用中wx:if的控制,errmsg为查询失败时显示的信息。
  • 在主页面查询按钮的点击事件中采用了wx.navigateTo传递快递查询的参数。(物流接口:http://www.kuaidi100.com/query?type=快递公司代号&postid=快递单号)。 在详情页面中,只需在onLoad(生命周期函数--监听页面加载)中用options接受参数即可。
  • 用wx.request发起网络请求。
参考资料:微信小程序官方文档wx.request发起网络请求
  • 注意: 在创建项目时,填写了AppID,发起网络请求需要在开发设置中配置服务器域名,如下图所示。
  • 开发者工具-创建小程序

    i微信公众平台-设置
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,491评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,856评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,745评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,196评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,073评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,112评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,531评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,215评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,485评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,578评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,356评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,215评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,583评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,898评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,497评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,697评论 2 335

推荐阅读更多精彩内容