使用gulp解决小程序代码包过大问题

简介: 使用gulp解决小程序代码包过大问题

前言

在开发小程序项目的过程中,由于功能的不断增加导致了代码包体积的越来越大。相对其体积进行一下压缩处理,看了几篇给小程序瘦身的博客,决定给自己的项目做一套配置文件,使用gulp来支持小程序文件的编译以及上传之前压缩文件的空行之类的。

通过gulp实现代码处理,要进行一些必须文件的配置,放在小程序根目录下,然后将小程序的所有文件移至src下。

  • gulpfile.js -- 使用了插件功能,支持gulp开头的插件
const gulp = require('gulp')

const SRC_DIR = './src/**/**/**/*'
const DIST_DIR = './dist/'
// Load plugins
const $ = require('gulp-load-plugins')()
const path = require('path')
const autoprefixer = require('gulp-autoprefixer')
const htmlmin = require('gulp-htmlmin')
const jsonminify = require('gulp-jsonminify2')
const gutil = require('gulp-util')
const combiner = require('stream-combiner2');
const babel = require('gulp-babel')
const uglify = require('gulp-uglify')
const rename = require("gulp-rename")
const minifycss = require('gulp-minify-css')
const runSequence = require('run-sequence')
const jsonlint = require("gulp-jsonlint")
// 获取 gulp-imagemin 模块
// var imagemin = require('gulp-imagemin')


// watch
gulp.task('watch', () => {
    gulp.watch(SRC_DIR + '.js', ['jsmin'])
    gulp.watch(SRC_DIR + '.json', ['jsonmin'])
    gulp.watch('./src/res/**', ['assets'])
    gulp.watch(SRC_DIR + '.wxml', ['wxmlmin'])
    gulp.watch(SRC_DIR + '.wxss', ['wxssmin'])
})

// js
function jsmin() {
    return gulp
        .src(SRC_DIR + '.js')
        .pipe(
            babel({
                presets: ['@babel/preset-env']
            })
        )
        .pipe(
            uglify({
                compress: true
            })
        )
        .pipe(gulp.dest(DIST_DIR))
}

// json
function jsonmin() {
    return gulp
        .src(SRC_DIR + '.json')
        .pipe(jsonminify())
        .pipe(gulp.dest(DIST_DIR))
}

// 压缩图片任务
// 在命令行输入 gulp images 启动此任务
// gulp.task('images', function () {
//     // 1. 找到图片
//     gulp.src('images/1.jpg')
//     // 2. 压缩图片
//         .pipe(imagemin({
//             progressive: true
//         }))
//     // 3. 另存图片
//         .pipe(gulp.dest('dist/images'))
// });
// assets
function assets() {
    return gulp.src('./src/res/**').pipe(gulp.dest('./dist/res'))
}
// wxml
function wxmlmin() {
    return gulp
        .src(SRC_DIR + '.wxml')
        .pipe(
            htmlmin({
                collapseWhitespace: true,
                removeComments: true,
                keepClosingSlash: true,
                caseSensitive: true
            })
        )
        .pipe(gulp.dest(DIST_DIR))
}

// wxss
function wxssmin() {
    return gulp
        .src(SRC_DIR + '.wxss')
        .pipe(autoprefixer(['iOS >= 8', 'Android >= 4.1']))
        .pipe(rename(path => (path.extname = '.wxss')))
        .pipe(minifycss())
        .pipe(gulp.dest(DIST_DIR))
}
// no console
function nodebug() {
    return gulp
        .src('./dist/**/*.js')
        .pipe(stripDebug())
        .pipe(gulp.dest(DIST_DIR))
}

// build
gulp.task(
    'build',
    gulp.parallel(jsmin, jsonmin, wxmlmin, wxssmin, assets)
)

// publish
gulp.task('product', gulp.series(clean, "build", nodebug))

// clean - 不是gulp插件
const del = require('del')
function clean() {
    return del([DIST_DIR + '**'])
}
  • .babelrc -- 需要配置,不然async/await不能babel
{
    "plugins": [
        "transform-strict-mode",
        "transform-es2015-modules-commonjs",
        "transform-es2015-spread",
        "transform-es2015-destructuring",
        "transform-es2015-parameters"
    ],
    "presets": [
        "@babel/preset-env"
    ]
}
  • package.json -- node依赖,使用npm下载
{
  "name": "applets",
  "version": "1.0.0",
  "description": "",
  "main": "gulpfile.js",
  "dependencies": {
    "@babel/core": "^7.10.4",
    "@babel/preset-stage-0": "^7.8.3",
    "babel-plugin-transform-es2015-modules-commonjs": "^6.26.2",
    "babel-plugin-transform-es2015-parameters": "^6.24.1",
    "babel-plugin-transform-es2015-spread": "^6.22.0",
    "babel-plugin-transform-strict-mode": "^6.24.1",
    "del": "^5.1.0",
    "gulp": "^4.0.2",
    "gulp-autoprefixer": "^7.0.1",
    "gulp-babel": "^8.0.0",
    "gulp-htmlmin": "^5.0.1",
    "gulp-jsonlint": "^1.3.2",
    "gulp-jsonminify2": "^1.0.2",
    "gulp-load-plugins": "^2.0.3",
    "gulp-minify-css": "^1.2.4",
    "gulp-rename": "^2.0.0",
    "gulp-uglify": "^3.0.2",
    "run-sequence": "^2.2.1",
    "stream-combiner2": "^1.1.1"
  },
  "devDependencies": {
    "@babel/plugin-transform-strict-mode": "^7.10.4",
    "@babel/preset-env": "^7.10.4",
    "babel-plugin-transform-es2015-destructuring": "^6.23.0",
    "babel-preset-stage-0": "^6.24.1"
  },
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}

说明

  • 流程详见 gulpfile.js 注释
  • 如果用到了less或者sass,可以配置watch,目前我的项目中没有用到,gulp的目的就是发布。如果需要实时调试可启用watch
  • 建议关闭微信的es6转es5,代码压缩
  • gulp版本的不同,会有同步和异步处理的问题
  • gulp.task 移除了三参数语法,现在不能使用数组来指定一个任务的依赖。gulp 4.0 加入了 gulp.series 和 gulp.parallel 来实现任务的串行化和并行化。
  • 任务函数中,如果任务是同步的,需要使用 done 回调。这样做是为了让 gulp 知道你的任务何时完成。
  • 如果任务是异步的,有多个方法可以标记任务完成:1. 回调,2. 返回流(Stream),3. 返回 Promise,4. 返回子进程。
  • 将task通过 js 函数的提升特性,可以将一些task定义为函数,好处就是私有化,不过就不再是gulp的命令,需要通过主task来启动。
  • 若需要同步任务,想避免显式调用done方法,可以将任务添加到串行队列执行,任务提供异步返回,保持和gulp3 一致就行。

可能出现的问题

  • 小程序组件间传值和事件,不要使用大驼峰,通过gulp-htmlmin压缩wxml代码时,pages内的页面会被转为全小写

    • js大小写是敏感的,html大小写是不敏感的,因此属性和事件的传递建议使用小写
    • 不使用gulp-htmlmin代码压缩wxml文件
  • 小程序border为1rpx时提供gulp-minify-css压缩后,1rpx就变成了0,因此需要使用1px作为border的宽度
相关文章
|
3月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
799 1
|
26天前
|
人工智能 小程序 JavaScript
【一步步开发AI运动小程序】十四、主包超出2M大小限制,如何将插件分包发布?
本文介绍了如何从零开始开发一个AI运动小程序,重点讲解了通过分包技术解决程序包超过2M限制的问题。详细步骤包括在uni-app中创建分包、配置`manifest.json`和`pages.json`文件,并提供了分包前后代码大小对比,帮助开发者高效实现AI运动功能。
|
7月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的箱包存储系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的箱包存储系统附带文章源码部署视频讲解等
53 5
|
3月前
|
开发框架 小程序 JavaScript
小程序代码丢失!反编译找回
小程序源代码的容易获取问题确实存在一些潜在的安全隐患。然而,现在的小程序开发框架采用像 Babel 这样的打包工具,将 JavaScript 逻辑代码混合在一个文件中并进行转编译,使其变得难以理解。
64 0
小程序代码丢失!反编译找回
|
8月前
|
JavaScript Java 测试技术
基于小程序的移动学习平台+springboot+vue.js附带文章和源代码说明文档ppt
基于小程序的移动学习平台+springboot+vue.js附带文章和源代码说明文档ppt
58 0
|
5月前
|
存储 小程序 Java
【小程序分包】小程序包大于2M,来这教你分包啊
本文介绍了如何通过分包解决uniapp小程序包体积过大的问题。由于版本升级导致包体积超过2M,即使压缩静态资源也无法满足发布要求。文章详细讲解了分包的原因、步骤及注意事项,并提供了实操示例,帮助读者理解并实现小程序分包,从而减小主包大小
230 1
【小程序分包】小程序包大于2M,来这教你分包啊
|
4月前
|
小程序 JavaScript Go
代码总有一个是你想要的分享63个微信小程序源
分享63个微信小程序源代码,包括电商系统、同城拼车、博客等多种应用,涵盖C#、Node.js、Golang等技术栈。每个项目附带源码和示例,适合初学者和开发者参考学习。提取码:8888,代码效果参考:http://www.603393.com/sitemap.xml。
117 2
|
5月前
|
小程序 前端开发 JavaScript
微信小程序实现微信支付(代码和注释很详细)
微信小程序实现微信支付(代码和注释很详细)
|
5月前
|
小程序 JavaScript 前端开发
微信小程序开发必备前置知识:基本代码构成与语法
【8月更文挑战第8天】微信小程序的基本代码构成与语法
130 0
微信小程序开发必备前置知识:基本代码构成与语法
|
5月前
|
小程序 JavaScript 安全
微信小程序实现云闪付支付(代码和注释很详细)
微信小程序实现云闪付支付(代码和注释很详细)