本文主要是介绍工厂手持安卓设备APP场景下uniapp和安卓原生开发的对比分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
去年上半年,我们整合了本市某行业各个工厂手持安卓设备app的功能需求,主要包括红外扫码(条形码和二维码)、标签打印机蓝牙打印、工时填报、流程审批等,特点是工厂内网使用,用户量小但是每天的使用量非常大,且用于车间工人生产包装产品的关键环节,app出问题会造成工厂停工停产的严重后果。
由于市场竞争激烈,行业内卷造成最终争取到的用于开发的金额不高,导致开发周期很短,对于原生安卓开发来说,没有足够的人/天,无论是时间还是单价。经过慎重考虑,我们决心采用uni-app来开发这一款产品。基于Vue框架的uniapp可以使用Vue.js、HTML、CSS等前端语言进行开发,具备Vue的优秀特性,如数据绑定、组件化、虚拟DOM等,大大提高了开发效率,同时得益于uniapp的流行,它的社区非常活跃,有大量插件可供使用,也有很多问题和解决方案可供参考。,以便我们能够快速向客户交付产品。
我们的开发人员从开发第一个功能页面扫码录入信息的表单,仅仅用了很短的时间就开发完成,然而交付功能测试后遇到了无法承受的问题。在测试人员用扫描枪测试时发现扫描码中有中文的话到输入框会乱码,这是WebView渲染的问题,只有原生渲染才可以解决这个问题。uniapp端内置了一个基于 weex 改进的原生渲染引擎,提供了原生渲染能力。在 App 端,如果使用 vue 页面,则使用 webview 渲染;如果使用 nvue 页面(native vue 的缩写),则使用原生渲染。也就是说只是一个最开始的需求扫描枪扫码的功能,就导致前面所讲的那些uniapp的相关vue的优点荡然无存了。
nvue 总结:
- nvue 页面均采用 flex 布局,不支持其他布局方式,需要注意的是 flex 默认为竖向排列,即 flex-direction: column。
- 目前不支持在 nvue 页面使用 scss、less 等预编译语言。
- 不能在 style 中引入字体文件,nvue 中字体图标的使用参考:weex 加载自定义字体。
- nvue 暂不支持运行在模拟器上。
还有一个问题就是相比于早已经存在了十几年的React Native,nvue (native vue 的缩写)貌似是个很新的东西,用起来非常不灵活,社区里面的帖子也很有限。所以,对于任何的app开发框架来讲,我们还是降低期待,凑合着用吧,都差不多。
这篇关于工厂手持安卓设备APP场景下uniapp和安卓原生开发的对比分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!