微信小程序开发自从诞生依赖就备受瞩目,虽然功能上有较多的限制,但是由于其便捷性与低成本,各大企业和品牌纷纷加入小程序开发阵营。
微信小程序的开发门槛相比移动应用低多了,那么我们在开发微信小程序的时候有哪些常见问题呢?今天蓝畅信息技术就来和大家聊一下

域名必须是HTTPS
小程序后台配置的域名,有服务器域名、业务域名、消息推送域名、普通二维码域名,前三者必须是HTTPS域名,普通二维码域名可以是HTTP域名;
wx.navigateTo跳转不生效
带有tabbar的页面,必须使用wx.switchTab进行跳转;
input组件placeholder字体颜色
写在placeholder-class里面的color并不生效,需要写在placeholder-style里面就可以了;
如何获取shareTickets(可以解密微信群ID)
获取shareTickets需要在app.onLaunch或者app.onShow里面才能获取到,而不是page.onShow,请一定要注意;注:建议在app.onShow里面去获取,app.onLaunch不是一直会执行;
tabbar在切换时页面数据无法刷新
tabbar的实现可能是显示和隐藏view,所以,不会一直调用page.()方法,可以尝试把代码逻辑写在page.onShow()里面,或者在onTabItemTap方法中处理;
wx.previewImage图片预览
预览的图片URL必须是HTTPS开头,不能是本地图片;
getPhoneNumber获取手机号
目前该接口针对非个人开发者,且完成了认证的小程序开放。个人开发者是没办法调用这个API的;
如何去掉自定义button灰色的圆角边框
主要是button的伪元素设置了样式,去掉即可: button::after{ display: none;};
wx.playVoice音频播放
保证音频文件已经在本地,比如在wx.startRecord后,可以获取到本地临时的tempPath。或者提前调用wx.downloadFile来下载资源文件,然后再播放;
API老版本兼容
可以用wx.canIUse或者wx.getSystemInfoSync来获取version和SDKversion进行判断,老版本给出相应提示即可;
获取系统信息
wx.getSystemInfo,可得到系统语言、屏幕宽高、微信版本号、操作系统、设备像素比、客户端甚础库版本等信息;
image组件底部有间隙
image组件默认底部会有间隙,可以设置为块元素(display: block),也可以设置vertical-align: top;
回到页面顶部
回到页面顶部,有两种方式:
(1)使用scroll-view设置为纵向滚动,然后设置scroll-top值;
(2)使用wx.pageScrollTo方法,此方法是1.4.0开始支持,所以要做低版本兼容;
textarea是APP的原生组件,层级最高
是个大坑,在有textarea的页面,不要做弹出框设计,建议在输入大段文本时,单独成一个新页面;
小程序中canvas的图片不支持格式
格式图片,在开发工具里面可以正常显示,真机上没有显示。建议修改成带https开头的url形式;
一段文字如何换行
小程序中唯一可以实现换行的标签组件是text,注:text中不支持,只能使用进行换行;
设置最外层标签的margin-bottom在IOS下不生效
margin-bottom在安卓和开发工具里面都正常,就是在IOS下不起效,建议改成padding-bottom;
删除体验版,仍然有缓存?
开发过程中,可能会遇到,删除小程序的体验版,但是缓存依然存在。建议把开发版和线上版都删除,因为小程序缓存是共用的;
开发者工具无法复制、粘贴代码
开发者工具中,经常会遇到无法复制、粘贴、搜索代码,有时还会出现,在A文件输入,内部跑到了B文件中,大写的尴尬。遇到这种情况,建议重启微信开发者工作。
本文来自网络 由蓝畅整理,经授权后发布,本文观点不代表Infocode蓝畅信息技术立场,转载请联系原作者。