uni-app在跨平台小程序中的实践

uni-app在跨平台小程序中的实践

 

 1. 背景 

随着移动互联网的高速发展,各家大厂的小程序百花齐放,在用户规模及商业化方面都取得了极大的成功。微信小程序的日活超过5亿,其他追赶者如:支付宝、百度、字节跳动小程序的月活也纷纷超过3亿。鉴于小程序相比App,无需下载等待,有更高的激活率,相比H5有更好的下单转化率,汽车报价业务线借助各平台的优势,大力发展小程序业务。

目前国内头部应用中,有一半以上部署了小程序。整个小程序生态现在有腾讯、阿里巴巴、百度、字节跳动、手机厂商、京东、360、美团、网易等9大类。然而各家平台的开发规范完全不一样,同时研发几家主流平台的小程序和快应用,对于研发团队提出了挑战,在前端团队人数有限的情况下,如何能搞定诸多平台的小程序是摆在我们面前的难题。

 

 2. 技术选型 

任何框架都首先要服务于实际业务需求,技术的选型也需根据研发团队成员的技术方向和具体情况而定,对于项目建设而言技术框架没有最好的只有最适合的。我们从核心需求、技术栈、支持跨平台小程序、运行性能、社区生态、开发工具等几方面对市面上的开发框架进行预研和对比。

 

2.1

核心需求

由于研发资源有限,在没有额外人力增加的情况下,原来的H5研发人员要同时承担跨平台小程序的开发,核心需求是提高研发效率。经过调研,市面上支持跨平台小程序的主流框架有uni-app和taro,本文主要针对这两种开发框架进行对比。

 

2.2

uni-app和taro的共同点

 taro是京东开发的多端统一开发框架,支持用 react 编写一次代码,生成能运行在微信/百度/支付宝/字节跳动小程序、H5、React Native 等的应用。uni-app 是DCloud开发的使用 vue.js 开发跨平台应用的前端框架,开发者编写一套代码,可编译到iOS、Android、H5、小程序等多个平台。由于笔者所在部门有专门的App原生开发人员,从性能角度来考虑,不需要开发框架支持App端,焦点主要集中在支持小程序和H5方面。两者具有如下共同点:

  • 均支持微信、百度、支付宝、字节跳动等小程序及H5;

  • 均支持使用 npm/yarn 安装管理第三方依赖;

  • 均支持使用 ES6 甚至更新的ES规范;

  • 均支持使用 less/scss/ts 等预编译器;

  • 均支持进行应用状态管理,taro 支持 Redux/Mobx,uni-app 支持 vuex。

     

2.3

uni-app和taro各自优缺点

图片

前端团队人数有限的情况下,相对react,我们团队更熟悉vue技术栈,学习成本更低,开发时间和风险更低,且uni-app在不同平台运行兼容性更好,有官方推荐的IDE,所以我们决定使用uni-app作为跨平台小程序的开发框架。

 

 

 3. 应用案例 

3.1

uni-app的项目结构

一个uni-app工程,默认包含如下目录及文件:

图片

图 1 uni-app 项目结构

 

3.2

渲染引擎

uni-app有2种渲染引擎:基于weex的原生渲染,以及webview渲染。

如果使用 vue 页面,则使用 webview 渲染;如果使用 nvue 页面(native vue 的缩写),则使用原生渲染。

如果你不开发 App,那么不需要使用 nvue。虽然 nvue 也可以多端编译,输出 H5 和小程序,但 nvue 的 css 写法受限,所以如果不需要支持App的情况下,就不需要使用 nvue。在 App 端某些 vue 页面表现不佳的场景下使用 nvue 作为强化补充。

 

3.3

uni-app与vue开发的区别

虽然uni-app遵循了vue语法,但是还是存在一些差异:

 

【DOM标签不一样】

  • div 改成 view;

  • span、font 改成 text;

  • a 改成 navigator;

  • img 改成 image;

  • select 改成 picker;

  • iframe 改成 web-view;

  • ul、li没有了,都用view替代。做列表一般使用uList组件。

     

【生命周期函数不一样】

uni-app在原来vue的生命周期函数上又新增了很多新的函数;

uni-app 支持 onLaunch、onShow、onHide 等应用生命周期函数;

uni-app 支持 onLoad、onShow、onReady 等生命周期函数。

生命周期执行顺序为: App.vue: onLaunch(应用) ->  App.vue: onShow(应用)-> index.vue: onLoad(页面)-> index.vue: onShow(页面)-> index.vue: created(vue)-> index.vue: onReady(页面)-> index.vue: mounted(vue)-> index.vue: updated(vue)

-> App.vue: onHide(应用)-> index.vue: onHide(页面)-> App.vue: onError(应用)。

 

【安装第三方库问题】

原来vue项目中通过npm install安装的第三方库,大多数无法直接在uni-app中使用,需要在uni-app的插件市场找类似的库。

另外uni-app 在非 H5 端不支持window、document、navigator 等浏览器的对象,以及cookie等浏览器特性。

 

3.3

实际运行效果

通过实际验证,基于uni-app开发的代码分别发布为微信小程序、百度小程序、快手小程序、字节小程序等后,兼容性不错。对于一些平台特性,还可以通过条件编译,实现各平台差异化编译,调用各平台的特色功能,如适配各平台的获取用户信息、获取用户手机号等方法。其中顶部导航栏个性化定制在字节小程序中默认不开放,需要小程序主体信用分大于90分,评级达到S,才可以申请。而微信小程序、百度小程序、快手小程序均默认支持。

图片

图2 汽车报价小程序在各平台的运行效果

 

 4. 应用效果和收益

汽车报价业务线目前基于uni-app已经同时支持微信小程序、百度小程序、字节小程序、快手小程序等多个平台,后续还将扩展其它平台的小程序及快应用。在熟练掌握uni-app的语法和工具后,研发效率可以提3-4倍以上。后续我们将基于uni-app框架实现可视化编辑工具,通过丰富的组件可视化拖拽生成小程序,进一步提高小程序和H5页面的研发效率。

 

作者|张慧吉、伍新生

原文链接:https://www.cnblogs.com/88223100/p/practice-of-uni-app-in-cross-platform-applet.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:uni-app在跨平台小程序中的实践 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月19日

相关文章

  • 用户订阅付费如何拆解分析?看这篇就够了

    会员制的订阅付费在影音娱乐行业中已相当普及,近几年,不少游戏厂商也开始尝试订阅收费模式。在分析具体的用户订阅偏好以及订阅付费模式带来的增长效果时,我们常常会有这些疑问: 如何从用户的整体付费行为中具体拆解订阅付费事件并分析? 想要了解当前应用内用户的整体订阅概况? 订阅用户和非订阅用户在留存与付费偏好是否存在差异? …… 而这些都能在华为分析服务—订阅分析中…

    Android 2023年4月25日
    00
  • 汽车之家Unity前端通用架构升级实践

    背景介绍 随着之家3D虚拟化需求的增加,各产品线使用Unity引擎的项目也越来越多,新老项目共存,代码维护成本也随之增加。代码质量参差加之代码规范仍没有完全统一产生高昂学习成本进一步加重了项目维护负担。 为应对这些问题,我们决定借助主机厂数科产品线销冠神器VR版本大升级为契机,开发一套移动端通用Unity代码框架,旨在统一Unity项目开发流程和规范,使不同…

    Android 2023年5月9日
    00
  • .NET Core部署到linux(CentOS)最全解决方案,常规篇

    本文为大家介绍使用 .NET Core部署到Linux服务器的方法,通过本文你将了解到Linux在虚拟机下的安装、Xshell,Xftp的使用方法、git在linux下的交互使用以及.net core在linux下的发布与运行全过程,本文皆在总结了一些经验与笔记在部署过程中遇到的一些问题,同时分享给大家,供大家参考,欢迎讨论交流。 1、Linux操作系统、X…

    C# 2023年4月28日
    00
  • 跑步课程导入能力,助力科学训练

    HUAWEI Health Kit为开发者提供用户自定义的跑步课程导入接口,便于用户在华为运动健康App和华为智能穿戴设备上查看来自生态应用的训练课表,开启科学、适度的运动训练。 跑步课程导入能力支持生态应用在获取用户的华为帐号授权后,将跑步课程数据写入至华为运动健康App,并在已有的华为智能穿戴设备连接并支持课程导入时,直接将课表推送到设备上,用户可以轻松…

    Android 2023年5月11日
    00
  • 这种开发方式你了解吗?

    随着移动互联网的发展,移动应用程序的需求越来越高,而原生应用程序的开发成本和时间较高,导致一些企业选择采用H5技术构建应用程序。 但是,H5技术在性能、用户体验、功能等方面仍有局限性,因此,有些企业转而选择「hybrid + 小程序」技术架构来构建应用程序。 相对于H5应用程序,小程序在用户体验、性能、功能等方面有很多优势。首先,小程序不需要像H5应用程序那…

    Android 2023年4月25日
    00
  • Android报”SecurityException”如何解决?

    首先我们需要知道在Android中,每个应用程序都会运行在自己的Sandbox中,这是为了保证应用程序之间的安全性和隔离性。这意味着当我们试图从应用程序中访问另一个应用程序或系统的一些敏感资源时,我们可能会遇到”SecurityException”异常。 该异常表示当前的应用程序没有足够的权限来执行某个操作。通常可以通过以下两种方式来解决该问题: 申请相关权…

    Android 2023年4月3日
    00
  • Android报”ActivityNotFoundException”如何解决?

    Android应用程序在运行过程中,如果没有正确设置相关的配置参数或者代码逻辑存在问题,就会导致某些异常情况的出现。其中,”ActivityNotFoundException”是其中比较常见的一种异常,它表示无法找到指定的Activity组件,本文将从原因和解决办法两个方面详细讲解。 一、异常原因 包名或类名指定错误 如果在AndroidManfiest.x…

    Android 2023年4月3日
    00
  • .NET Core 环境变量详解

    一、概述 软件从开发到正式上线,在这个过程中我们会分为多个阶段,通常会有开发、测试、以及上线等。每个阶段对应的环境参数配置我们会使用不同的参数。比如数据库的连接字符串,开发环境一般我们都是连接的测试库。以前这种情况通常是 COPY 两个同名的配置文件来进行处理,然后在本地就使用本地的配置,生产环境就使用生产环境的配置文件,十分麻烦。而 ASP .NET CO…

    C# 2023年4月25日
    00
合作推广
合作推广
分享本页
返回顶部