当前位置: 首页 > article >正文

使用uniapp开发微信小程序使用uni_modules导致主包文件过大,无法发布的解决方法

在使用uniapp开发微信小程序时候,过多的引入uni_modules的组件库,会导致主包文件过大,导致无法上传微信小程序,主包要求大小不超过1.5MB.分包大小每个不能超过2M。
解决方法:分包。

1.对每个除了主页面navbar的页面进行分包操作。

在page.json文件进行分包配置。分包代码例子:

	//主包的页面
    "pages": [{
            "path": "packages-main/tab-bar-pages/home/index",
            "style": {
                "navigationBarTitleText": "主页",
                "enablePullDownRefresh": false,
                "navigationStyle": "custom",
            }
        },
    ],
    //这样我们就可以把login页面和register页面进行分包处理。
    "subPackages": [
        {
            "root": "packages-sub/login/",
            "name": "login",
            "pages": [{
                    "path": "login",//指代login.vue文件
                }
            ]
        },
                {
            "root": "packages-sub/register/",
            "name": "register",
            "pages": [{
                    "path": "register",
                }
            ]
        },
	]

然后就可以在微信小程序的代码依赖分析中找到分包的效果。
在这里插入图片描述

2.对uni_modules中引入的模块进行代码转移和分包处理。

如果我们把uni_modules代码直接转移到分包文件夹,打包完成后,还是会把代码打包入主包文件中,需要我们手动把组件分包引入。但是需要注意的是,对uni_modeluse会导致组件互相引入的时候出现循环报错,需要我们一个一个解决。另外在引入的页面也会出现无法找到组件的问题,需要我们对page.json文件增加引入入口。

1.uniapp使用easycom属性在page.json文件内把移动到分包内的ui组件进行加载。

    "easycom": {
        "autoscan": true,
        "custom": {
            "^uni-(.*)": "@/packages-sub/components/uni-$1/components/uni-$1/uni-$1.vue",
    },
    "pages":.......

2.对uni_modules文件进行分包处理,尽量挪动组件互相引用少的。


//文件目录:packages-sub\components\uni-popup\components\uni-popup\uni-popup.vue
 "subPackages": [
        {
            "root": "packages-sub/components/uni-popup/",
            "name": "uni-popup",
            "pages": [{
                    "path": "components/uni-popup/uni-popup"
                }
            ]
        },
	]

3.对使用到的页面进行页面组件引入配置。

同样打开page.json文件,如在登陆页面使用到了uni-popup组件。就需要配置一下。

        {
            "root": "packages-sub/login/",
            "name": "login",
            "pages": [{
                    "path": "login",
                    "style": {
                        "navigationBarTitleText": "登录",
                        "enablePullDownRefresh": false,
                        "componentPlaceholder":{
                            "uni-popup":"view",  //view在这里起到一个占位符的作用,这样可以解决找不到引入文件的问题。       
                        }
                    }
                }
            ]
        },

以上方法可以解决uni_modules的分包问题。当然我们在进行微信小程序开发时,在开发之初就要处理好代码的分包问题,避免在发版时无法发布代码产生问题。另外在进行组件开发时最好使用原生微信小程序的组件,或者自己开发。插件用时爽,分包的时候问题有点难。


http://www.kler.cn/a/399769.html

相关文章:

  • 深度学习基础练习:代码复现transformer重难点
  • Ubuntu安装配置MySQL(远程登录)
  • 前端基础(四十一):实时获取麦克风音量
  • 深入探索Scala迭代器:实用技巧与最佳实践
  • C/C++中使用MYSQL
  • 计算机网络之会话层
  • 银河麒麟设置ip
  • Java retainAll() 详解
  • 滑动窗口入门(LeetCode——1456定长字符串中元音字母的最大数目)
  • 【在Linux世界中追寻伟大的One Piece】手写序列化与反序列化
  • 利用hive元数据统计数据量
  • 编程之路,从0开始:结构体详解
  • 大数据技术Kafka详解 ① | 消息队列(Messages Queue)
  • 微信小程序底部button,小米手机偶现布局错误的bug
  • etcd部署(基于v3.5.15)
  • C++标准模板库 -- map和set
  • 怎么看待Ai发展前景?
  • 用python中的tkinter包实现进度条
  • 【C++】C++11 新特性揭秘:序章
  • window的Anaconda Powershell Prompt 里使用linux 命令
  • AIGC----生成对抗网络(GAN)如何推动AIGC的发展
  • 11.12.2024刷华为OD-集合的使用,递归回溯的使用
  • 【青牛科技】D2030 14W 高保真音频放大电路介绍和应用
  • 使用Mac下载MySQL修改密码
  • 【C++】了解map和set及平衡二叉树和红黑树的原理
  • 使用docker快速部署Nginx、Redis、MySQL、Tomcat以及制作镜像