微信小程序开发经验总结(遇到的坑和问题汇总)

前言:

前段时间公司打算做一款基于线下服务的小程序,涉及到扫码支付,地图,充值,会员体系等功能。由于公司暂时没有新招小程序开发人员,而我之前又有过开发小程序的经验。所以,这个小程序开发自然而然也就交给我来做了。(ps:我在这家公司的岗位是ios开发。)
说到小程序,可能很多人会误解了,这个不就是web嘛?其实小程序并不等于web,准确来说,他结合了原生app和web的各自优势。既有原生app那样流畅顺滑的体验,又具有web开发的优势,页面变动灵活,一次开发多端适用。在开发小程序之前,我们需要申请开发者账号,配置环境,等等。如何开始我的第一个小程序,不在本文的讨论范畴之内,大家在网上可以找到很多的教程。这里不一一赘述。(ps:下文微信小程序简称小程序)

正文:

一:https部署以及设置合法域名。

1.小程序向后台请求接口必须使用https,包括web-view里的网页,如果项目中有用到web socket,那么也必须使用wss协议。https证书一般会用第三方的。比如阿里云的。
2.在微信小程序管理后台,还需要配置合法域名。当然,在后台还没有部署https之前,我们也可以进行开发调试,只需要设置不校验合法域名,https证书等即可。

二:post请求,json数据格式转换

当我们向后台进行post请求的时候,当我们的传输数据的格式为json的时候,需要设置

'content-type': 'application/x-www-form-urlencoded' 

三:微信小程序谁是首页的问题

当我们在开发原生应用的时候,我们一般会在程序的入口,设置我们程序的第一个页面,但是反观小程序,并没有找到类似的方法,原来在小程序中,app.json文件中的pages数据的第一个元素,就是首页。但是,我们有时候会有这样的需求,微信扫码直接跳转小程序内部的指定页面,那么,这时,只需要在小程序管理后台,设置扫码打开的页面路径填好即可。

四:微信小程序开发单位问题

我们再开发iOS的时候默认使用pt;在开发Android的时候,我们使用dp,sp等单位;在开发web的时候使用em,rem等单位。但是在我们的小程序里我们只要记住rpx这一个单位就好了,这样我们开发出来的小程序就完美的运行在各式各样屏幕的手机上了。no!no!no,也是有特殊情况的,有时候我们就不能使用rpx,比如使用到canvas的时候,那么就只能使用px为单位,那么,如何做到屏幕适配呢?我的做法是使用wx.getSystemInfo这个api来获取到运行手机的屏幕的宽度和高度,那么根据UI的标注图的屏幕宽高,就可以换算出一个比例来了。如果大家有更好的做法欢迎交流指正。

五:wxss文件中不支持本地图片

如果我们有一个需求:添加一张背景图,根据web开发思维,肯定是在background-image:中设置本地图片的路径,但是在微信小程序上这是行不通的。微信小程序的background-image只支持网络图片。

六:wxml文件中可以使用三目运算符

如果我们要在wxml文件中做逻辑判断,那么我们可以使用三目运算符,列如:class=" {{type==1?'style_one':'style_two'}}"。这里的意思是通过type的不同,渲染不同的wxss文件。注意!这里要分清单引号与双引号,不能弄混淆。

七:this.setData和直接赋值的区别

这两者都可以造成data里数据的改变,但是this.setData赋值才会造成wxml里面数据的改变,也就是同步更新渲染界面,而直接赋值只会让data里数据发生变化,但是界面并不会改变。看代码:


//wxml文件
<text>我的名字是{{name}}</text>

//js文件
//数据源
data: {
    name:'',
  },

onLoad: function (options) {
    this.data.name='张三'//只会使data里数据发送改变,但是界面不会发生改变,界面仍显示”我的名字是“
    console.log(this.data.name)//打印出来的结果是”张三“

    this.setData({
      name: '张三'
    })
    //此时,界面数据才会发生改变,变成”我的名字是张三“
  },

八:cover-view组件

这是小程序上特有的组件,它其实是由客户端创建的原生组件。这些组件有:cavans,map,vedio等,如果想要在原生组件上覆盖组件的话,添加view,text,button都是行不通的,必须使用cover-view和cover-image组件,具体用法,可以参考微信小程序官方文档。下面我来说说cover-view中踩过的坑。cover-view对css支持真的不太友好,虽然我们设置背景色,字体大小,宽高等都没啥问题,但是,
1.在web开发中,如果我们想要给文字设置删除线,那么使用text-decoration即可实现,但是抱歉,cover-view不支持这个属性。
2.曾经我尝试给cover-image添加旋转的动画,但是发现怎么都实现不了,我猜测可能也是不支持,后来换了其他方法实现这个需求了。
3.cover-view是有hidden属性的,但是我奇葩的发现了,在ios10系统上,cover-view改变hidden属性的时候报错了,后来换成了wx:if,就这样神奇的解决了。
4.使用cover-view组件的时候,如果cover-view在模拟器上表现是好的,别忘了使用真机跑跑看,说不定会有意想不到的结果哦。
5.总之,使用cover-view的时候一定要小心谨慎。
这些是我遇到的关于cover-view坑,应该还有,欢迎大家补充。

九:微信小程序不能操作DOM树

web开发中,可以使用getElementById()访问documnent中的某一个元素,顾名思义,就是通过id来获取元素,但是微信小程序没有windows对象,所以小程序不能直接操作dom树,小程序采用的都是mvvm的设计模式,数据双向绑定。类似于vue.js的写法。

十:微信小程序分享功能如何实现

微信有庞大的流量,既然有这么得天独厚的平台,那么在小程序开发分享功能也是水到渠成的。比如,要开发一个类似外卖平台发红包的功能,照以前开发app逻辑,app客户端负责开发“发红包”的逻辑,集成分享的sdk,把红包发出去即可,再使用web开发“领红包”的逻辑,也就是领红包的页面是一个web页面。一开始,我也是打算这么设计这个架构的。但是在web页面重新登录,在打开小程序,中间涉及到的登录流程又会显得比较复杂。后来参考了其他小程序的分享功能,把分享页面也定义成一个小程序原生页面,而不是小程序内的web-view页面。这样设计,实际开发后,发现其实简单了许多。

十一:配置普通链接二维码规则需要注意的地方

这里有一个地方需要注意。开发小程序的时候,我们有一个使用微信扫码打开指定页面的需求。那么我们需要配置一个普通链接二维码规则,但是我们在开发测试的过程中,我们需要来测试我们的跳转功能是否好用。二维码规则需要发布才可以全网使用,测试链接也是只针对管理员开发者体验着等有效果。


二维码配置页面.png

十二:地图导航等功能需要注意的地方

微信小程序集成地图功能非常简单,但是需要注意的是我们使用的是腾讯地图,也就是gcj02坐标系,如果后台使用的是其他坐标系,那么我们需要转换。如果需要实现导航功能,那么小程序内的map组件是没有这个能力的,我们需要调用wx.openLocation来实现,其实这个api是打开了微信内置的腾讯地图,这样,就是我们熟悉的微信导航服务了,可以在这里打开手机内的百度地图,高德地图,腾讯地图这些app来进行导航了。

十三:wx.showToast吐槽

wx.showToast({
  title: '成功',
  icon: 'success',
  duration: 2000
})

微信提供的这个api,默认的提示图标是一个小勾勾,但是即使不设置icon,也会出现这个图标,这就很难受了。如果我想提示失败呢?你给我一个对勾的图标?我的解决办法就是自己写了一个toast-view,或者可以找ui设置一张空白的图片放上去吧,嘻嘻,我没试过,但是应该可行。

十四:添加点击事件

在wxml文件中,text,image,view,button等标签都可以添加点击事件。(ps:这点比移动开发中只有button才能添加点击事件,其他的只能添加手势方便了许多)使用button的时候有一点需要注意,那就是button有默认的样式,我们如果不需要这个样式,需要手动清除。

十五:关于提审上线

根据经验,微信小程序第一个版本上线提审,时间会久一点,可能1-2天,后续版本一般2-3个小时。(工作时间)我感觉微信小程序的审核没有app store那么严格。大家不用太担心~

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

推荐阅读更多精彩内容