微信小程序总结及踩坑记录

前言

小程序开发已有近一年之余,对于小程序的认识也从入门到了熟练。遂写下这篇总结,以供参考。关于小程序的介绍,就不赘述了,我们直接开门见山:

学习路径

1.微信小程序最好的教程肯定是官方的文档啦,点击这里直达微信官方文档

2.新建一个quick start项目,了解代码结构。

3.去github上搜索一些小程序demo工程,了解参考其写法,前端大佬justjavac总结了一篇小程序开发资源汇总,直达链接微信小程序开发资源

目录结构介绍

这里我简单描述下,个人认为小程序和vue语法很相似,我拿vue来做比较,方便认知。
app.js: 这个是小程序的入口文件,相当于vue 的main.js 一些全局变量都可在此定义。
app.json: 这个比较重要,小程序路由比较简单,在此配置绝对路径即可,设置网络超时时间、设置多底部 tab 等也是在此json文件中定义的。

页面生命周期

onload 及 onShow 这两个用的多,相当于vue的created 及mounted 这两个周期 ,页面传参的话,在onload方法中获取参数。

关于踩坑

当我们遇到解决不了的问题时,寻求前人之鉴是很有效的,疑难问题解决,可上小程序社区寻找答案:社区链接

踩坑总结

做小程序项目中,遇到的些坑,总结了一下:

1.小程序页面空白的可能原因:

  • css兼容性问题
  • lineShopId长度太长,字符转数字Number
  • post请求参数加上encodeURIComponent解析字符串

2.事件分为bindtap 及catchtap bind事件绑定不会阻止冒泡事件向上冒泡,catch事件绑定可以阻止冒泡事件向上冒泡

3.image背景图片地址必须是url或者base64/本地资源无法通过 css 获取 可以使用网络图片,或者 base64,或者使用 标签。

4.{{}} 不能执行方法,只能处理简单的运算如 “+ - * /”,比如遇到遍历list,每个item的金额需要格式化,只能在js里预先格式化好再setData一遍。

5.微信开发工具Mac客户端无法发送请求,wx.request 报错,需要在“详情”下勾选“不校验安全域名,TLS版本以及HTTPS证书”。

6.下拉刷新不回弹,要在 complete 回调中运行 wx.stopPullDownRefresh()。

7.设置图片横向滚动,需要在 scroll-view 的 CSS 中添加 white-space:nowrap;display:flex;而 scroll-view 里面的 item 要设置成 display:inline-block。

8.小程序组件的监听,可使用properties中的 observer方法,极为有效。

9.小程序废弃了wx.getUserInfo接口,并不在自动弹出授权询问弹框。如需想获取用户信息:采用button:
<button open-type="getUserInfo" bindgetuserinfo="getUserInfo">获取用户信息</button>
我们可以自己封装一个modal, 再把button组件放上去,用此来引导客户进行授权,授权成功后,就可以调用wx.getUserInfo,接着调用wx.login来获取code 换取openid

10.textarea 的键盘bug
show-confirm-bar='false'设置不生效,导致键盘还带有“完成”按钮,预期效果是没有“完成”button~这个值如果要设置为true的话随便输入就可以了,但是如果是要设置false的话就需要设置变量或者留空:show-confirm-bar='' 或者 show-confirm-bar='{{showConfirm}}'

11.实现客服button样式
position: absolute,定位一个button到你想要的位置,透明度设置为0即可,同时给button设置属性open-type="contact"。

  • 这里要注意button的open-type属性是在基础库1.1.0开始支持的,自己要做一下兼容处理.
  • button也可以改成其他样式,有些同学为了获取formId,就把页面所有可点击区域都用button按钮来实现

12.小程序navigateTo网络延迟产生连续跳转问题,可以采用节流函数解决。

13.在小程序中打开移动端H5网页,需要配置业务域名,并且该H5网页必须是https协议,如果该H5地址是hash模式,需要在web-view的标签里填写网址时要在地址后添加/#/。

最后小程序和H5的区别可以参看此文章:https://zhuanlan.zhihu.com/p/23536784

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

推荐阅读更多精彩内容