微信小程序项目踩过的几个坑
一、前言
近期,开始了一段辛酸的还未开始就已经结束的“创业”(参见我的第二次创业,以梦为马,莫负韶华)。大体上是开发了一款微信小程序,关于创业这件事情就不细说了,本文主要介绍一下开发小程序的过程中踩过的几个坑。
二、注册
开发一款功能全乎的小程序,在未动键盘开始码代码之前就要涉及到账号注册、微信认证、支付申请等等,这里面也有一些坑。
首先是必须要企业认证才能有微信支付功能,以个人名义申请不能进行支付。微信认证还算容易,只需要支付300元即可。支付申请的时候会让你选择需要申请的经营种类,此处如果与企业执照上相同会比较容易通过,我们的经营项目不太一致,刚开始写的比较简单被直接驳回,后面我写了一段比较长的话详细解释了一下要做个什么、为什么申请此类型,估计审核的人被我感动了,于是顺利通过。
三、HTTPS和备案
如果小程序需要和后台交互,那么交互时只能选择域名的方式,且此域名必须经过ICP备案,并且只能采用HTTPS方式。
ICP备案比较麻烦,可以直接选择购买阿里云服务器,这应该是最方便的方式了吧。
HTTPS建议使用百度云,可以申请到一年的免费证书,申请也比较容易。
四、开发
回归到本行。其实小程序开发是个涉及到方方面面的工作,要求还是蛮高的,一套下来基本也就是个全栈工程师了。
小程序本身就分前台和后台,就类似与网站开发,wxml对应html、wxss对应css、js就是js、还多了个json用于配置等。说白了就是微信把这些东西以一定的方式封装起来了,但是我个人感觉封装的也不是那么理想,所以有点不太顺手。
小程序通信的后台可以采用各种语言,相当于网页的后台,也基本等同于restful接口。此项目我们使用了python的django框架,开发起来还蛮容易的。
整个一套下来,哪方面都有接触,我的合伙人包亮是个编程大牛,对我进行了很多指导,我对开发这件事情和js、python这两种语言都有了全新的认识。
言归正传,下面开始介绍开发过程中踩过的坑。
4.1 js回调
刚开始js代码写的很冗长,一个函数有上百行。并不是我不懂得代码编写的艺术,而是小程序的js开发往往是一个请求中的sucess以及fail中嵌套另一个请求,函数只能越写越长,最后各种功能交织在一起,变量也混杂在仪器,我自己实在看不下去了,于是开始重构,将一些功能提取出来组成函数,整体代码清爽了不少,但是出现了一些让我很费解的bug,大神简单看了一下直接指出问题来了,本来应该嵌套的异步函数写成了并列,这样导致函数在执行的时候没有时间上的先后顺序,于是就会出现莫名其妙的bug,这个问题我是有所注意的,但是有些地方也确实没有注意到,他告诉我你应该将各种回掉函数作为参数传入,这样就不会再出问题。简单如下:
function b() {
// do something when sucess
}
function a() {
wx.request({
url:'...',
sucess: function(res) {
b();
}
})
}
a();
这是我原来写的方式,当然比这复杂的多,所以不注意的时候就会将b写到a的后面,其实真正的方式应该是这样:
function b() {
// do something when sucess
}
function a(aSucess) {
wx.request({
url:'...',
sucess: function(res) {
aSucess()
}
})
}
a(b);
这样就很清晰的知道a函数里当请求成功的时候做了什么事情,因为直接在调用a的时候就已经传入其中了。
4.2 app.js中的异步函数如何保证可靠性
有的时候需要在app.js的onLaunch事件中向后台请求一些数据,比如用户信息等等(非微信用户信息,但需要与微信openid关联),取出这些信息后在加载用户页面的时候会再向后台请求些数据进行展示等,但是app.js和页面之间无法进行普通回掉,这样就会造成在app.js中还没有请求完成,数据还是undefined而页面中使用此数据就会造成错误。后来查看了一些文档,发现可以在app.js中为特定数据自定义事件,用于在其他页面判断,方式如下:
app.js中:
wx.request({
url: '',
success: res_user_info => {
if (this.userIdCallback) {
this.userIdCallback(res_user_info)
}
this.globalData.userId = res_user_info.data.id;
}
})
这样就在app.js中定义了一个userIdCallback事件,该事件完成的时候表示已经从后台取到了用户数据。在其他页面即可通过此种方式进行判断:
if (app.globalData.userId == null || app.globalData.userId == undefined) {
app.userIdCallback = res_user_id => {
// do something
}
} else {
// do something
}
即首先判断此数据是否已经请求到,如果还未完成则等待此数据完成,然后在其回调函数中再完成有关操作。
4.3 tabBar之间的切换
如果在app.js中设置了tabBar,则页面底部会出现相应的导航栏,但是页面中使用wx.navigateTo跳转到的页面底部不显示导航栏,并且如果需要切换到导航栏内的任何页面,都需要使用wx.switchTab函数而不是wx.navigateTo函数。
4.4 数据绑定
微信小程序没有数据双向绑定,在Page对象中设置的data只能单向改变前台渲染,而前台改变无法同步更改此变量。那么如果需要将前台的变化也同步到后台,只能监控前台控件的变化事件,如input的bindinput事件,在此事件中对输入值进行判断,如下:
<input bindinput="bindMoney" value="{{money}}" />
其中value="{{money}}"用于后台到前台的绑定,而bindinput则用于前台到后台的绑定,如下:
bindMoney: function (e) {
var value = parseInt(e.detail.value);
this.setData({
money: value
})
}
并且小程序在绑定变化的时候前台会出现undefined的情况,如果是图像的话就会造成请求错误,倒是无伤大雅,时间很短,前台基本不会察觉。
五、提交审核
这是最坑的一点,吭哧吭哧的做了半天,最后居然因为种种非技术原因而无法通过审核。好吧,最为个体我们真的无法说什么,只能对微信这个大平台言听计从,希望我们更改相应页面后能够通过审核。审核太严失去了自由的土壤,微信如何保证有好的产品出现呢?
六、总结
本文简单介绍了在微信小程序开发过程中踩过的一系列坑,希望对后来者能够有所帮助。
微信小程序项目踩过的几个坑的更多相关文章
- mpvue微信小程序项目踩坑记录
1.mpvue入门教程, http://mpvue.com/mpvue/quickstart.html # . 先检查下 Node.js 是否安装成功 $ node -v v8.9.0 $ npm - ...
- 我的微信小程序入门踩坑之旅
前言 更好的阅读体验请:我的微信小程序入门踩坑之旅 小程序出来也有一段日子了,刚出来时也留意了一下.不过赶上生病,加上公司里也有别的事,主要是自己犯懒,就一直没做.这星期一,赶紧趁着这股热乎劲,也不是 ...
- 小程序——微信小程序初学踩过的坑
微信小程序初学踩过的坑 一.前言 最近因为某些需要和个人兴趣打算开发一下微信小程序,经过在官方网站上的基本了解,我大体知道了微信小程序开发的大致过程,其实最本质的就是MVVM,借用了很多模式上 ...
- 微信小程序开发01 --- 微信小程序项目结构介绍
一.微信小程序简单介绍: 微信官方介绍微信小程序是一个不需要下载安装就可使用(呵呵,JS代码不用下载吗?展示的UI不用下载吗?)的应用,它实现了应用“触手可及”的梦想,用户扫一扫或搜一下即可打开应用. ...
- 高仿Readhub小程序 微信小程序项目【原】
# News #### 项目介绍微信小程序项目涉及功能 https://gitee.com/richard1015/News https://github.com/richard1015/News 高 ...
- 【微信小程序项目实践总结】30分钟从陌生到熟悉 web app 、native app、hybrid app比较 30分钟ES6从陌生到熟悉 【原创】浅谈内存泄露 HTML5 五子棋 - JS/Canvas 游戏 meta 详解,html5 meta 标签日常设置 C#中回滚TransactionScope的使用方法和原理
[微信小程序项目实践总结]30分钟从陌生到熟悉 前言 我们之前对小程序做了基本学习: 1. 微信小程序开发07-列表页面怎么做 2. 微信小程序开发06-一个业务页面的完成 3. 微信小程序开发05- ...
- 微信小程序项目实战之天气预报
概述 微信小程序项目实战之天气预报 详细 代码下载:http://www.demodashi.com/demo/10634.html 一.准备工作 1.注册微信小程序 2.注册和风天气账号 3.注册百 ...
- 微信小程序项目实战之豆瓣天气
概述 微信小程序项目实战之豆瓣天气 详细 代码下载:http://www.demodashi.com/demo/10943.html 一.准备工作 1.注册微信小程序 2.在小程序设置中设置reque ...
- 《微信小程序项目开发实战:用WePY、mpvue、Taro打造高效的小程序》(笔记1)WePY开发环境的安装
WePY的安装或更新都通过npm进行,全局安装或更新WePY命令行工具,使用以下命令: npm install wepy-cli -g 稍等片刻,成功安装后,即可创建WePY项目. 注意:如果npm安 ...
随机推荐
- happymall 第十一章订单表 数据表设计
为订单号生成唯一索引,用用户id和订单号生成组合索引提高查询效率.
- Mac下安装MySQL及启动等常用命令
总结了下mac下的mysql安装步骤: eclipse JavaEE 下载 JDK -9 macosx下载 一.安装及启动服务 1. MySQL Server 下载.(以mys ...
- 小白的Python之路 day5 configparser模块的特点和用法
configparser模块的特点和用法 一.概述 主要用于生成和修改常见配置文件,当前模块的名称在 python 3.x 版本中变更为 configparser.在python2.x版本中为Conf ...
- Windows7下设置定时启动(关闭)虚拟机
曾记否,忆当年,开启或者关闭虚拟机,度秒如年~ ⒈石头,剪刀,布,C.D.E盘随便找一个,然后在里面找个静谧的墙角, 新建一个文件:vmstart.bat 添加:"C:\Program Fi ...
- 腾讯云中ssL证书的配置安装
https://cloud.tencent.com/document/product/619/12797 配置 Nginx 和 HTTPS 完成以上准备工作,就要开始配置 Nginx 和 HTTPS ...
- 解决mysql不是内部或外部命令
安装Mysql后,当我们在cmd中敲入mysql时会出现'Mysql'不是内部或外部命令,也不是可运行的程序或其处理文件. 工具/原料 mysql cmd 方法/步骤 1 打开我的电脑在我的电脑右键中 ...
- 如何给网站添加CNZZ站长统计功能代码的常用办法
前几天有个客户来问小编怎么给网站添加上CNZZ站长统计工具,其实这个很简单,只要把cnzz免费代码复制到我们的footer文件就行.今天小编正好有空就来分享一下具体的操作过程. 首先要想获得这个免费的 ...
- 使用VSCode 编译调试QT程序
预备知识 bat文件,或者其他的脚本语法. qmake基本语法,qmake shadow build是啥. vscode 的task,lanch的配置. 前提 各个程序正确安装,即使用QtCreato ...
- flannel 网络问题排查
1. 如果你发现 k8s容器无法访问外网? 重启docker 原因是,docker重启后会重新生成网桥.网络不通的原因是flannel启动后生成的网络覆盖了docker的网络,当你重启docker后, ...
- 改变UITableView选中行高亮的颜色
UIView *backView = [[UIView alloc] initWithFrame:self.contentView.frame]; backView.backgroundColor = ...