小程序开发中的那些坑【新手必备】

前言

前段时间加入了开发小程序的队伍,我可算是把所有的坑的踩了。

现在把开发中那些注意点和各位小伙伴分享下。

一、小程序无法多图同时上传

uni.uploadFile只能支持单图上传,没上传一张调用一次接口,因此建议使用将所有请求放在promise里面进行发送。

这块要注意的点:

  • uploadFile需要设置域名

  • 编辑图片获取图片信息时,需要用getImageInfo获取小程序帮我们暂存的图片路径。同时也要设置域名。

  • 小程序在真机调试的时,图片可以成功上传,体验版本不打开调试无法上传。这块问题定位也是上传图片的域名问题,可能后台给的图片域名线上和线下不同。

二、小程序Json.parse时遇到特殊字符报错

场景:页面A跳转到页面B携带大量信息拼接在url后传送。

跳转之前将大量信息转成json字符串,然后在B页面Json.parse。

 A页面
 let transferData= JSON.stringify(data);
 B页面
 let getData = JSON.parse(transferData);

  • 解决方案一

    先将Stringify后的数据进行编码,然后再转换之前进行编码,这样可以解决特殊字符串jsonparse报错问题。

A页面
let transferData= JSON.stringify(data);transferData = encodeURIComponent(transferData);

B页面
let getData = JSON.parse(decodeURIComponent(transferData));

弊端:但是因为数据是拼接再url后面的,数据过长被截掉了怎么办?因此让我们看下解决方案二

  • 解决方案二

使用uni.$emit进行通信,这种方法不适用此场景。因此A页面跳转到B页面,B页面还未加载。

这种方式使用在A页面监听,打开B页面时,B页面触发A页面的监听事件,这时候A页面接收到B页面的数据。

// A页面  
onLoad(){  
    // 监听事件  (获取B页面的数据)
    uni.$on('login',(usnerinfo)=>{  
        this.usnerinfo = usnerinfo;  
    })  
}, 
// B页面

uni.$emit('login', {data:'这是我要给A页面的数据'});

很明显这种方法不适用于此场景

  • 解决方案三

    使用vuex进行通讯

  • 解决方案四

使用globalData。

globalData是一种比较简单的全局变量使用方式。
在小程序中有globalData的概念,uni-app也实现了此功能,在App.vue可以定义globalData。

<script>
export default {
    globalData: {
        text: 'lxc'
    },
    methods: {
        ··· ···
    }
}
</script>

赋值:

A页面
getApp().globalData.text = 'aliasName'

取值:

B页面
console.log(getApp().globalData.text) // 'aliasName'

页面渲染:
globalData的数据渲染,可以在页面的onShow生命周期进行操作。

弊端:但是!!globalData如果在当前页面刷新,定义的globalData就失效了。

原因很简单,这个不是本地缓存,是一种变量缓存刷新就会消失。

  • 最终方案

最后决定用本地缓存在解决

 uni.setStorageSync('传输的数据名称key',  encodeURIComponent(JSON.stringify(data)));
JSON.parse(decodeURIComponent(uni.getStorageSync( '传输的数据名称key')));

弊端:目前这种解决方式的弊端查了下:小程序的数据缓存,最大支持10M。我们需要传输的数据是字段串类型,不会超过10M,因此此种方式暂时安全。【万一后续需求改了呢】

三、原生组件遮挡弹出框问题

弹出框被原生组件遮挡的问题可以在弹出框中使用cover-view来代替view,但是这会导致弹出框的显示效果发生变化,需要修改弹出框的样式。

更好的替代方法是:

如果原生组件是canvas,可以在弹出对话框时用image代替canvas。

如果原生组件是textarea则可以使用view来代替

四、小程序给scroll-view设置vh

在iphonex的尺寸下,scroll-view设置固定高度为100rpx,不会影响页面其他地方的滚动

{F179638}

但是切换到别的设备比如iphone5,scorll-view还是会占据相同的高度,会导致底部的数据【红色块】无法显示,只能通过页面滚动查看这个页面所有的数据。

因此设置将XXXrpx设置为 XXvh。

  • vh是相对于视口的高度。视口被均分为100单位的vh

h1{font-size:8vh;}
如果视口的高度是200mm,那么上述代码中h1元素的字号将为16mm,即(8x200)/100

五、微信小程序运行的时候总是提示Uncaught TypeError: Cannot read property 'call' of undefined

场景:刚开始代码小不出现错误,到后来项目越来越大,代码和创建的页面多了起来,差量编译就开始报错了,而且越来越频繁,仅仅是我在js中删除了一行空格再ctrl+s 差量编译都开始报这个错误,特别是速度很快连续的ctrl+s 差量编译 时特容易报错,非常影响开发效率,报出来错误只能在uni中ctrl+f5重新整个编译,干等时间非常长。

ps:查了一下目前官方还没给出解决方案。也有说是运营商的问题。。。 在此记录下

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

推荐阅读更多精彩内容