HTML5+ API 爬坑记录

背景:

有个比较早些使用5+开发的项目, 最近两天反馈了一些问题, 解决过程在此记录;

坑1: plus.gallery.pick 选择图片没有进入回调

HTML5+ API Reference

在 联想小新 平板电脑上选择相册图片进行上传时, 打开相册瞬间 应用会自动重启, 相册倒是有打开, 不过应用重启了, 导致业务也完成不了, debug 没有任何错误, gallery.pick 成功和失败的回调都没有进入;

原因分析: 应用采用的强制横屏模式, 在 manifest.json 中 是像如下配置的, 而平板系统的横竖屏设置是锁定竖屏的, 可能应用在跳转到系统相册界面时突然从横屏转向竖屏是某些冲突导致, 至于更深层的原因暂时还没有能力排查;

复制代码
"screenOrientation" : [ "landscape-primary" ],
"plus": {
    "distribute" : {
        "orientation" : [ "portrait-primary", "portrait-secondary" ], 
    }
}

临时解决办法: 将平板电脑的屏幕方向设置为横屏, 并将其锁定;

坑2: plus.barcode.Barcode 扫码控件 返回数据错误

HTML5+ API Reference

创建扫码控件 扫描比较复杂的条形码时返回数据错误, 扫到的总是一些不相干的数据, 极小概率可以扫到正确的数据, 代码中已经配置 条码类型过滤器, filters, 代码和条码如下

复制代码
scan = new plus.barcode.Barcode('bcid',[
	"plus.barcode.CODE128",
	"plus.barcode.QR"
]);

原因分析: 期初以为是配置的码制问题, 怀疑码不是code128 的, 看了下内容, 除了 code128, 只能是code39 才支持这种格式的内容, 改了发现还是不行, 好像没啥用; 也down 了官方demo 下来, 配置这个filters 也是一样的结果;

经过多次查看官方示例时发现, 传入的filters 的内容格式似乎不太对, 人家的示例传入的filters 是没有引号的!!!

解决办法: 将filters 的引号去掉;

javascript 复制代码
scan = new plus.barcode.Barcode('bcid',[
	plus.barcode.CODE128,
	plus.barcode.QR,
	// plus.barcode.EAN13,
	// plus.barcode.EAN8,
	// plus.barcode.AZTEC,
	// plus.barcode.DATAMATRIX,
	// plus.barcode.UPCA,
	// plus.barcode.UPCE,
	// plus.barcode.CODABAR,
	// plus.barcode.CODE39,
	// plus.barcode.CODE93,
	// plus.barcode.ITF,
	// plus.barcode.PDF417,
]);
相关推荐
无尽夏_2 小时前
HTML5(前端基础)
前端·html·html5
Jagger_2 小时前
敏捷开发流程-精简版
前端·后端
FIN66682 小时前
昂瑞微冲刺科创板:创新驱动,引领射频芯片国产化新征程
前端·安全·前端框架·信息与通信·芯片
GISer_Jing2 小时前
ByteDance——jy真题
前端·javascript·面试
睡美人的小仙女1272 小时前
浏览器为何屏蔽本地文件路径?
前端
真的想不出名儿2 小时前
Vue 中 props 传递数据的坑
前端·javascript·vue.js
FIN66682 小时前
昂瑞微:深耕射频“芯”赛道以硬核实力冲刺科创板大门
前端·人工智能·科技·前端框架·信息与通信·智能
阳光阴郁大boy2 小时前
星座运势网站技术解析:从零打造现代化Web应用
前端·javascript
烛阴3 小时前
武装你的Python“工具箱”:盘点10个你必须熟练掌握的核心方法
前端·python
sorryhc3 小时前
如何设计一个架构良好的前端请求库?
前端·javascript·架构