crmeb 小程序包大小超过2M的解决方法

crmeb 小程序包大小超过2M的解决方法,第1张

微信限制了小程序的代码包不能超过2MB,这主要是出于对小程序启动速度的考虑。但是,2MB 的大小也限制了小程序功能的扩展,如果大小超出了2MB该如何解决呢?

什么是分包加载:

小程序一般都是由某几个功能组成,通常这几个功能之间是独立的,但会依赖一些公共的逻辑,且这些功能一般会对应某几个独立的页面。那么小程序代码的打包,可以按照功能的划分,拆分成几个分包,当需要用到某个功能时,才加载这个功能对应的分包。

对于用户来说,小程序加载流程变成了:

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时,还是需要分析它们的优劣势,选择适合自己的。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12543934.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存