# 微信小程序学习 起手式DEMO仿肯德基(待完善)
## 小程序? 大场景?
微信小程序本质上来说就是一个 HTML 5(移动网页) 应用,用view、scoll-view代替了div标签等,换汤不换药。在微信中运行时,微信小程序获得更多的系统权限。首先是数据缓存能力,这可以让用户在打开一个小程序的时候将程序的主要框架缓存到微信上,下一次就可以快速打开了。微信创始人张小龙曾说过,微信应用号希望实现的目标是“用完即走,无需安装和卸载”,也就是说以后当你要使用一个应用时,只需要在微信里搜索就可以直接使用了,如摩拜、美团等小型使用低频的app使用该套技术可大量节省开发成本。最近又新增了开放个人开发、公众号关联推送的加强,可谓使用场景不容小觑。
## 起手做什么?
由于本人吃货一枚,家门口有一家KFC,之前KFC的app经常有一些福利卷,既然用惯了这个便捷实惠的app,于是就做它了。
言归正传,先来分析一下一步一步该做啥,做一个小demo成就感还是满满的。
![](http://xurenjie.cn:3000/img/KFC/KFC1.png)
### 完成的功能:
附近位置选择-联动菜单导航-模拟数据-抽屉式购物车-获取用户微信信息-页面传值-数据生成订单
## 体验地址
#### [体验点我,比较大,请耐心等待2333,最好clone下来本地跑55555~](http://xurenjie.cn:3000/img/KFC/KFC_gif.gif)
http://xurenjie.cn:3000/img/KFC/KFC_gif.gif
抱歉!!GIF太卡了太卡了,简易clone下来本地跑起来效果最佳
直接点餐会自动为你找到最近的餐厅,不过离最近的kfc太远的不太行
## 用到的工具和文档:
1. **开发调试工具:** [微信小程序平台教程](https://mp.weixin.qq.com/debug/wxadoc/dev/),安装好最基本的啦!稍微过一遍简易文档。
2. **开发‘字典’文档:** [微信小程序开发教程手册文档](https://www.w3cschool.cn/weixinapp/9wou1q8j.html)功能使用方法都在上面挺全的。通过
阅读文档了解页面的搭建、页面路由、导航跳转、数据绑定、条件渲染、列表渲染、scroll-view、request、radio、modal、toast、map、位置、数据缓存、动画、验证信息。
3. **easy-mock:** [easy-mock](www.easy-mock.com)模拟后端数据,后面会简单介绍配置。
4. **腾讯地图API:** [腾讯地图小程序](http://lbs.qq.com/qqmap_wx_jssdk/index.html)有地点搜索、关键词输入提示、逆地址解析(坐标位置描述)地址解析(地址转坐标)距离计算、获取城市列表、获取城市区县的一步配置教程。
5. **WeUI** [WeUI github](https://github.com/weui/weui-wxss)微信专用的结构样式组件库,加速开发速度,BEM规范代码,增强可读性
## 目录结构
├── app.js
├── app.json
├── app.wxss
├── pages
│ ├── .DS_Store
│ ├── KFC
│ │ ├── KFC.js
│ │ ├── KFC.wxml
│ │ └── KFC.wxss
│ ├── card
│ │ ├── card.js
│ │ ├── card.wxml
│ │ └── card.wxss
│ ├── halladdress
│ │ ├── .DS_Store
│ │ ├── halladdress.js
│ │ ├── halladdress.wxml
│ │ └── halladdress.wxss
│ ├── index
│ │ ├── index.js
│ │ ├── index.wxml
│ │ └── index.wxss
│ ├── logs
│ │ ├── logs.js
│ │ ├── logs.json
│ │ ├── logs.wxml
│ │ └── logs.wxss
│ ├── menu
│ │ ├── index.html
│ │ ├── menu.js
│ │ ├── menu.wxml
│ │ └── menu.wxss
│ ├── order
│ │ ├── order.js
│ │ ├── order.wxml
│ │ └── order.wxss
│ └── takeout
│ ├── message
│ │ ├── message.js
│ │ ├── message.wxml
│ │ └── message.wxss
│ ├── qqmap-wx-jssdk.min.js
│ ├── takeout.js
│ ├── takeout.wxml
│ └── takeout.wxss
├── style
│ ├── .DS_Store
│ └── weui.wxss
└── utils
└── util.js
#### 页面注册
#### app.json
"pages": [
"pages/index/index", // 首页
"pages/KFC/KFC", // K金商城页
"pages/menu/menu", // 菜单页
"pages/card/card", // 卡包页
"pages/order/order", // 订单页
"pages/takeout/takeout", // 外卖地图页
"pages/takeout/message/message", // 填写外卖信息页
"pages/halladdress/halladdress", // 附近餐厅页
"pages/logs/logs" // 日志页
]
我们可以通过官网的文档或W3C教程上初始化了一个小程序目录,小程序的每个页面都放在pages目录下
每次添加一个新页面,都需要先在app.json.page下注册。
## 数据模拟
mock.js大红大紫,让前端独立于后端,用它来模拟KFC数据
不太清楚使用的同学可以参考:
1. [mockjs前端开发独立于后端](https://i.jakeyu.top/2016/08/19/mockjs%E8%AE%A9%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E4%B8%8D%E4%BE%9D%E8%B5%96%E5%90%8E%E7%AB%AF/)
2. [掘金:easy-mock](https://juejin.im/post/58ff1fae61ff4b0066792f6e)
3. [mock.js那点事](https://juejin.im/post/58f9eec0a22b9d00658ee4b7)
### easy—mock创建数据
因为菜单中每个左侧的分类对应一组数据,在右侧也需要渲染类名,因此简单模拟结构
[{ "title": "这里放左边列表的组名",
"foodsIndex": [{
"name": "这里放每个食物的名字",
"price": "11.0",
"url": "http://imgm.4008823823.com.cn/kfcmwos/img//S/269_116012.jpg"
},
{},{},{}]
你可以尝试自己去扒[肯德基点餐](https://m.4008823823.com.cn/kfcmwos/menu.htm?classId=116),或者用我扒好的[肯德基API](https://www.easy-mock.com/mock/5905d4597a878d73716e2c6b/kfc/kfc)
## 地图API的使用
![](http://xurenjie.cn:3000/img/KFC/KFC2.png)
### [小程序地图初始化](https://www.w3cschool.cn/weixinapp/weixinapp-map.html)
**用toast优化耗时加载**
wx.showToast({
title: '地图加载中',
icon: 'loading',
duration: 0,
mask: true
})
**画图完成后用回调将Toast去除**
```javascript
this.mapCtx = wx.createMapContext('myMap', function () {
wx.hideToast();
})
```
WXML:
```html
<map id="myMap" longitude="{{longitude}}" latitude="{{latitude}}"
style="width: 100%; height: 100%" markers="{{markers}}" covers="{{covers}}" scale="18">
</map>
```
### 腾讯地图API使用-逆地址解析
以搜附近地点渲染至页面列表为例
1. 引入核心类
[腾讯地图小程序版](http://lbs.qq.com/qqmap_wx_jssdk/index.html)下载js并获取key
```javascript
let QQMapWX = require('qqmap-wx-jssdk.min.js');
let demo = new QQMapWX({
key: '5Q2BZ-O3W24-V6DUN-DZ4Z7-H427K-WCB7R' // 必填
});
```
2. 调用API[reverseGeocoder](http://lbs.qq.com/qqmap_wx_jssdk/method-reverseGeocoder.html)
```javascript
demo.reverseGeocoder({
location: {
latitude: _latitude,
longitude: _longitude
},
get_poi: 1,
success: function (res) {
// console.log(res);
},
fail: function (res) {
console.log(res);
},
易小侠
- 粉丝: 6636
- 资源: 9万+
最新资源
- 电动汽车空调制冷系统电动压缩机匹配分析1.pdf
- 二氧化碳汽车空调系统设计及研究1.pdf
- 电动汽车驱动系统散热设计与试验验证.pdf
- McQuayDuctSizer(麦克维尔风管尺寸计算软件).zip
- 麦克维尔温湿度分析仪McQuayPsychrometricAnalyzer(hvac-eng.com).zip
- 麦克维尔管道测量仪McQuaypipesizer .zip
- 信捷XC系列PLC主从通讯程序
- 基于蒙特卡洛的电动汽车充电负荷生成
- 基于遗传算法的电动汽车有序充电优化调度 软件:Matlab 利用遗传算法对电动汽车有序充电进行优化;优化目标包括充电费用最低,充电时间达到要求(电动汽车充到足够的电)考虑电动汽车充电对电网负荷的影响
- FPGA 全部verilog代码实现I2C口master端口应用场景 1、FPGA通过I2C口配置TFP410MP 2、EDID配置,FPGA通过I2C口配置AT24C02 AT24C64; 访问地
- Matlab simulink 基于光伏和蓄电池的三端口
- FFT STM32+apFFT程序源代码+lunwen资料+教程讲解 适用于STM32F103平台,使用AD7606同步采集两路正弦信号,内置1024点全相位快速傅里叶变(apFFT)算法,直接计算
- 两电平svpwm算法verilog程序
- 基于改进的快速粒子群有源配电网动态无功优化 软件:Matlab 介绍:在含分布式电源的IEEE33进行无功优化,以无功最优和运行费用最优为目标函数进行优化,采用改进的快速粒子群算法进行计算
- 混合型APF,HAPF,电力牵引系统电能质量控制,高铁谐波补偿,高铁无功补偿,混合型有源电力滤波器,单相SVG,SVG,电力牵引系统谐波无功补偿
- 单机无穷大系统静态稳定性仿真模型
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈