什么是分包加载:
小程序一般都是由某几个功能组成,通常这几个功能之间是独立的,但会依赖一些公共的逻辑,且这些功能一般会对应某几个独立的页面。那么小程序代码的打包,可以按照功能的划分,拆分成几个分包,当需要用到某个功能时,才加载这个功能对应的分包。
对于用户来说,小程序加载流程变成了:
1.首次启动时,先下载小程序主包,显示主包内的页面;
2.当进入某个分包的页面,再下载这个对应分包,下载完毕后,显示分包的页面。
采用分包加载,对开发者而言,能使小程序有更大的代码体积,承载更多的功能与服务;而对用户而言,可以更快地打开小程序,同时在不影响启动速度前提下使用更多功能。
分包的划分:
在配置前,按照圆数功能对各个分包的内容进行划分,将同一个功能下的页面和逻辑放在童改一个目录下,把一些跨功能的公共逻辑放在主包下。
在分包划分时需注意:
1.包与包之间功能尽可能独立,避免分包与分包之间引用上的耦合。因为分包的加载是由用户 *** 作触发的,并不能确保某分包加载时,另外一个分包就一定存在,这个时候可能会导致 JS 逻辑异常的情况,例如亩型报「"xxx.js" is not defined」这样的错误;
2.一些公共的自定义组件,要放在主包内。
分包的配置:
在uni app中通过cli初始化的小程序目录结构如下:
src
main.js
App.vue
pages.json
manifest.json
orderPackages
pages
goodsDetail
myorder
pages
index
user
utils
目前小程序分包大小的限制:
整个小程序所橘耐首有分包大小不超过 4M
单个分包/主包大小不能超过 2M
以上只罗列了uni app框架分包加载的步骤, 原生小程序分包方法根据官方文档即可快速实现,小程序框架虽多, 大都大同小异,如果后续有使用其他框架进行开发,会进行补充。
如果你觉得这篇文章对你有点用的话,麻烦请给我们的开源项目点点star: http://github.crmeb.net/u/defu不胜感激 !
随着互联网开发技术的不断发展,小程序和APP的使用率也越来越高颂谨。微信小程序曾经还因为跳一跳这个小游戏火了一把,后来就在我们的生活中越来越普及了,比如使用小程序点单付款、在线填单邮寄快递、线上商城小程序等。
很多客户在咨询我们做软件开发的过程中,不太了解APP和小程序的区别,也不知道这两者该如何选择更好。下面喜妹就以喜望软件过往的开发经验来解决这个问题,好好讲讲APP和小程序的区别,方便各位更加清晰地做产品开发的决策。
一丨基础框架
移动端产品的设计规范和原则大致是相同的,但微信小程序由于受制于微信的框架,就与App在部分版块的表现形式上存在一些差异,主要体现在以下几个方面:
1顶部导航栏
小程序:导航栏右侧有个无法去除和编辑的胶囊(titlebar),原生的导航栏支持更改颜色,但字体颜色仅支持黑/白两种,设计时也不能在导航上增加其他功能。所以一些原本可安置在导航栏的定位、搜索、消息等模块的内容也自动下移,banner也是处于导航栏的下方。
虽然微信也提供自定义导航栏,支持加入搜索,将背景色、图片等跟导航栏融合在一起,但可能会需要重新调整界面和元素,量级大的话也会导致工作量增加。
App:通常在app的界面中,整个界面都是可以自定义,所以顶部的导航区域不受限制,可拓展性强,灵活性高。
2底部标签栏
底部标签栏是移动端产品的主要导航方式,主要表示用户当前所在的位置,会有选中与未选中两种切换方式。
App的标签栏高度和图标大小都可以自定义,也会有很多不同的表达形式,比如采用自由的、冲破边界的异形元素,在Tab切换时会有动效,容易吸引用户的注意力。
而小程序通常使用原生控件,icon的尺寸一般都是81*81px。Tab切换形式通常比较单一、常规,没有动态效果。
二丨功能模块
小程序是在微信的框架里面的,大小受微信的控制。目前小程序调整了开发可以用分包加载的方式将大小扩至12m,但跟原生APP比起来还是相差很大的。app一般可以达到几十兆,不受限制。
正因为内存的限制,再加上小程序仅限微信提供的接口功能,所以功能模块会跟APP有所不同。
一般小程序在功能架构上设置较为简单、轻量,适漏樱亩合一些工具属性的应用,符合“快速打开、用完即走”的理念,更贴近于生活中的吃喝玩乐。
小程序也能实现很多功能,比如消息通知、线下扫码、公众号关联等,但对于一些需要大量计算的功能类应用,如图片处理、文档编辑等,小程序是无法满足的。
原生App的内存就不受控制,功能模块可以根据产品定位随意增添,视觉效果的设计也更加人性化和绚丽丰富。
APP可以发挥的空间非常大,直播、电商、社区等比较复杂的应用都能实现,也能够在交互、视觉等用户体验上满足用户的高要求。你想要丰富、细化、个性化的功能,需要更大的容量来实现,就在APP上承载吧~
三丨引流推广
小程序因为背靠微信,可以与微信公众号进行互通跳转,活跃指数高,引流效果好。微信自带的「附近的小返森程序」功能,自带免费推广,帮助小程序被五公里范围内的微信用户搜索到。小程序是根据距离来排名,与品牌大小无关,离用户越近就排得越前。
但是微信对小程序进行了诸多限制,特别是流量获取方面,很多小程序的营销策略被腾讯禁止,比如三级分销等,严重的还会下架封号,且很难申述。
而APP内部的功能和内容由运营者全权把控,虽受制于内存大小和流量成本,但好在营销策略可以灵活运用,推广方式和渠道很多,自由性更高。
四丨下载安装
App需要用户去应用市场下载,虽然下载渠道多,但对网络环境的依赖性强,占用手机空间较大。
而小程序可以通过二维码、微信搜索等方式立即加载使用,响应速度很快,占用手机内存空间可以忽略不计(只是部分微信缓存数据)。对于手机内存较小的用户,微信小程序就是一个福音。
五丨用户群
小程序:基于微信平台的应用,仅限微信用户,月活跃用户10亿+。
APP:上架在AppStore及Android应用市场,面向全球拥有智能手机的用户,也就是33亿+的用户量。
从精准度来讲,App大部分都是用户在应用商店中搜索下载的,用户的下载行为首先是基于对APP有兴趣,那么这样的用户群相对小程序而言更加精准。
六丨用户体验
1使用习惯
用户下载App后,是直接存在用户的手机桌面,要使用的时候打开手机,找到APP点击进入就能使用,打开方式更快速更方便。
小程序的入口比较深,需要打开微信进行查找或下拉获取,至少需要3步才能打开对应的小程序。而且现在小程序很多,用户很难想起之前使用过的小程序,大都是需要使用时才会去搜索。
2消息广告
App可以给用户推送消息,提示用户打开软件,增加启动和使用软件的频率,提升软件的活跃度。但有些app隔三差五的推送消息,甚至还有很多d窗广告,会给用户产生干扰,太多的未读提示逼死强迫症用户。
而小程序不允许主动给用户推送广告,只能回复模版消息,站在不打扰用户的角度来说,用户体验感比APP好。
七丨开发成本
1发布
App一般会向多个应用商店提交审核,根据每个应用商店不同的审核标准准备资料、调整修改和打包安装包,较为繁琐;而小程序只需要提交到微信公众平台审核即可。
2开发时间
做APP普遍都会开发安卓系统和iOS系统两种版本,这两个系统所用到的开发语言不同,安卓是Java和Koplin,iOS是Swift和Objective-C。现在苹果又出了暗黑模式,要设计2套UI图,同时还需要适配市场上的多款主流手机,开发时间相对较长。
小程序是基于腾讯的微信小程序开发框架进行开发的,开发技术类似HTML。一次开发就可以自动适配所有手机,所以开发时间会比APP短一点。
3开发费用
一个软件的开发一般都有原型UI设计、框架搭建、数据库设计、接口开发、第三方对接、PC管理系统开发、用户端安卓版开发、用户端苹果版开发、小程序开发等收费项目。
如果只做APP的话,就会减掉小程序开发的费用,反之只做小程序,就少了app前端的开发费用。
总的来说,小程序比APP少了一个前端的开发,费用是APP三分之二左右。
总结
小程序和App各有特色,两者的关系既可以相互补充,又可以完全独立。
小程序的开发难度、时间和成本相对较低,后期维护更容易,迭代更新的速度更快,用户运营更有优势。但小程序的用户体验方面略逊APP,内容体积有限制,总的来讲还是源于命名中的一个“小”字。小程序对于预算较低的初创公司不失为一个不错的选择。
而APP的开发难度较高,后期维护难,迭代更新相对慢,用户运营成本高,但是用户体验感更好、更丰富、原生。对于预算较高的中大型公司,可以通过大型APP沉淀用户数据,提升企业价值。
其实就两种技术而言,并不能完全肯定哪一种更好,只是适用于不同需求的客户。
APP
1适合相对成熟的公司
2充裕的开发时间
3足够的资金预算
4对交互设计和界面效果要求较高
5已经经过实际运营检测的商业模式
VS
小程序
1适合初创公司、中小企业、个体户
2相对较少的资金和时间
3创业、创新商业模式试水
4适合快速场景化服务
5需要向APP引流
最后,喜妹想说,大家在考虑选择小程序还是App时,还是需要分析它们的优劣势,选择适合自己的。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)