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,
]);
相关推荐
众生回避4 分钟前
鸿蒙ms参考
前端·javascript·vue.js
洛千陨5 分钟前
Vue + element-ui实现动态表单项以及动态校验规则
前端·vue.js
GHUIJS1 小时前
【vue3】vue3.5
前端·javascript·vue.js
&白帝&1 小时前
uniapp中使用picker-view选择时间
前端·uni-app
魔术师卡颂1 小时前
如何让“学源码”变得轻松、有意义
前端·面试·源码
谢尔登1 小时前
Babel
前端·react.js·node.js
ling1s1 小时前
C#基础(13)结构体
前端·c#
卸任2 小时前
使用高阶组件封装路由拦截逻辑
前端·react.js
Estrella162 小时前
经典 web 页面排版:三栏布局
前端·css·面试
lxcw2 小时前
npm ERR! code CERT_HAS_EXPIRED npm ERR! errno CERT_HAS_EXPIRED
前端·npm·node.js