微信小程序——gulp处理文件

作者: 冰星寒水 | 来源:发表于2017-02-08 15:32 被阅读2767次

    懒癌直接贴代码,想写在写
    因为最近搞了一下小程序,直接使用微信的开发者工具搞感觉有点不习惯,并且看了几篇给小程序瘦身的博客,决定给自己的项目做一套配置文件,使用gulp来支持sass scss文件编译以及上传之前压缩文件的空行之类的。

    至于使用gulp没有使用webpack的原因,因为我不想处理js文件,可能是我研究明白吧。后续还可以添加把assets目录里面的资源上传到ftp或者cdn的功能~

    JSON

    json文件开发时候直接复制到dist目录下,生产的时候使用jsonminify压缩

    gulp.task('json',() => {
      return gulp.src('./src/**/*.json')
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('jsonPro',  () => {
      return gulp.src('./src/**/*.json')
        .pipe(jsonminify())
        .pipe(gulp.dest('./dist'))
    })
    

    wxml

    wxml文件开发时候直接复制到dist目录下,生产的时候使用htmlmin压缩

    gulp.task('templates', () => {
      return gulp.src('./src/**/*.wxml')
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('templatesPro', () => {
      return gulp.src('./src/**/*.wxml')
        .pipe(htmlmin({
          collapseWhitespace: true,
          removeComments: true,
          keepClosingSlash: true
        }))
        .pipe(gulp.dest('./dist'))
    });
    

    wxss

    wxss文件,这个处理就比较多了,没有使用的时候只能使用css,对于我这种习惯sass的人来说有点痛苦。于是添加了sass支持,支持了.sass后缀的文件,会编译成wxss格式的,原有wxss文件中也支持了scss语法

    gulp.task('wxss', () => {
      var combined = combiner.obj([
        gulp.src(['./src/**/*.{wxss,sass}', '!./src/styles/**']),
        sass().on('error', sass.logError), // gulp sass编译
        autoprefixer([
          'iOS >= 8',
          'Android >= 4.1'
        ]), // autoprofixer 自动添加
        rename((path) => path.extname = '.wxss'), //重命名
        gulp.dest('./dist')
      ]);
    
      combined.on('error', handleError);
    });
    
    gulp.task('wxssPro', () => {
      var combined = combiner.obj([
        gulp.src(['./src/**/*.{wxss,sass}', '!./src/styles/**']),
        sass().on('error', sass.logError),
        autoprefixer([
          'iOS >= 8',
          'Android >= 4.1'
        ]),
        minifycss(), // 压缩 css文件
        rename((path) => path.extname = '.wxss'),
        gulp.dest('./dist')
      ]);
    
      combined.on('error', handleError);
    });
    

    JavaScript

    虽说微信的IDE也支持ES6,但是还不是很完善,所以我使用Babel编译js。使用uglify压缩的js

    gulp.task('scripts', () => {
      return gulp.src('./src/**/*.js')
        .pipe(babel({
          presets: ['es2015']
        }))
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('scriptsPro', () => {
      return gulp.src('./src/**/*.js')
        .pipe(babel({
          presets: ['es2015']
        }))
        .pipe(uglify({
          compress: true,
        }))
        .pipe(gulp.dest('./dist'))
    })
    

    gulpfile.js

    const gulp = require('gulp')
    const del = require('del')
    const path = require('path')
    const autoprefixer = require('gulp-autoprefixer')
    const htmlmin = require('gulp-htmlmin')
    const sass = require('gulp-sass')
    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")
    
    var colors = gutil.colors;
    const handleError = function(err) {
      console.log('\n')
      gutil.log(colors.red('Error!'))
      gutil.log('fileName: ' + colors.red(err.fileName))
      gutil.log('lineNumber: ' + colors.red(err.lineNumber))
      gutil.log('message: ' + err.message)
      gutil.log('plugin: ' + colors.yellow(err.plugin))
    };
    
    gulp.task('clean', () => {
      return del(['./dist/**'])
    })
    
    gulp.task('watch', () => {
      gulp.watch('./src/**/*.json', ['json']);
      gulp.watch('./src/assets/**', ['assets']);
      gulp.watch('./src/**/*.wxml', ['templates']);
      gulp.watch('./src/**/*.wxss', ['wxss']);
      gulp.watch('./src/**/*.sass', ['wxss']);
      gulp.watch('./src/**/*.js', ['scripts']);
    });
    
    gulp.task('jsonLint', () => {
      var combined = combiner.obj([
        gulp.src(['./src/**/*.json']),
        jsonlint(),
        jsonlint.reporter(),
        jsonlint.failAfterError()
      ]);
    
      combined.on('error', handleError);
    });
    
    gulp.task('json', ['jsonLint'], () => {
      return gulp.src('./src/**/*.json')
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('jsonPro', ['jsonLint'], () => {
      return gulp.src('./src/**/*.json')
        .pipe(jsonminify())
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('assets', () => {
      return gulp.src('./src/assets/**')
        .pipe(gulp.dest('./dist/assets'))
    })
    
    gulp.task('templates', () => {
      return gulp.src('./src/**/*.wxml')
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('templatesPro', () => {
      return gulp.src('./src/**/*.wxml')
        .pipe(htmlmin({
          collapseWhitespace: true,
          removeComments: true,
          keepClosingSlash: true
        }))
        .pipe(gulp.dest('./dist'))
    });
    
    gulp.task('wxss', () => {
      var combined = combiner.obj([
        gulp.src(['./src/**/*.{wxss,sass}', '!./src/styles/**']),
        sass().on('error', sass.logError),
        autoprefixer([
          'iOS >= 8',
          'Android >= 4.1'
        ]),
        rename((path) => path.extname = '.wxss'),
        gulp.dest('./dist')
      ]);
    
      combined.on('error', handleError);
    });
    
    gulp.task('wxssPro', () => {
      var combined = combiner.obj([
        gulp.src(['./src/**/*.{wxss,sass}', '!./src/styles/**']),
        sass().on('error', sass.logError),
        autoprefixer([
          'iOS >= 8',
          'Android >= 4.1'
        ]),
        minifycss(),
        rename((path) => path.extname = '.wxss'),
        gulp.dest('./dist')
      ]);
    
      combined.on('error', handleError);
    });
    
    gulp.task('scripts', () => {
      return gulp.src('./src/**/*.js')
        .pipe(babel({
          presets: ['es2015']
        }))
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('scriptsPro', () => {
      return gulp.src('./src/**/*.js')
        .pipe(babel({
          presets: ['es2015']
        }))
        .pipe(uglify({
          compress: true,
        }))
        .pipe(gulp.dest('./dist'))
    })
    
    gulp.task('dev', ['clean'], () => {
      runSequence('json',
        'assets',
        'templates',
        // 'sass',
        'wxss',
        'scripts',
        'watch');
    });
    
    gulp.task('build', [
      'jsonPro',
      'assets',
      'templatesPro',
      'wxssPro',
      'scriptsPro'
    ]);
    
    gulp.task('pro', ['clean'], () => {
      runSequence('build');
    })
    

    依赖

    这里的gulp-jsonminify2以及他相关的依赖根据自己的业务修复了一下解决了json空对象格式失败的问题

    "dependencies": {
        "autoprefixer": "^6.6.0",
        "babel-eslint": "^7.1.1",
        "babel-preset-latest": "^6.16.0",
        "del": "^2.2.2",
        "gulp": "^3.9.1",
        "gulp-autoprefixer": "^3.1.1",
        "gulp-babel": "^6.1.2",
        "gulp-eslint": "^3.0.1",
        "gulp-htmlmin": "^3.0.0",
        "gulp-jsonlint": "^1.2.0",
        "gulp-jsonminify2": "^1.0.0",
        "gulp-load-plugins": "^1.4.0",
        "gulp-minify-css": "^1.2.4",
        "gulp-postcss": "^6.2.0",
        "gulp-rename": "^1.2.2",
        "gulp-ruby-sass": "^2.1.1",
        "gulp-sass": "^3.1.0",
        "gulp-uglify": "^2.0.0",
        "gulp-util": "^3.0.8",
        "run-sequence": "^1.2.2",
        "stream-combiner2": "^1.1.1"
      }
    

    相关文章

      网友评论

      • 加载中_c485:请教一下,我想@import的样式,不被引进来,只是@import这句话还保留在wxss中,仅仅起到压缩作用就好,不要把import的样式引进来,我该怎么配置呢?
      • 荒野大瞟客:htmlmin压缩后报错,主要因为<input></input>的结尾标记被压没了,想请问一下,该如何解决
        荒野大瞟客:@冰星寒水 不是新项目,没办法
        冰星寒水:@荒野大瞟客 比如这个https://github.com/Tencent/wepy
        冰星寒水:@荒野大瞟客 现在已经有很好的小程序解决方案了,没有必要在用这套了
      • GerryLon:这个wxml文件用gulp-htmlmin不能压缩, 怎么办?
      • 开发者头条_程序员必装的App:感谢分享!已推荐到《开发者头条》:https://toutiao.io/posts/razcm8 欢迎点赞支持!
        欢迎订阅《JS大发好》https://toutiao.io/subjects/130833
      • 知晓程序:你好!我们是爱范儿旗下专注于小程序生态的公众号知晓程序(微信号 zxcx0101)。我们很赞赏你的文章,希望能获得转载授权。授权后,你的文章将会在知晓程序社区(minapp.com)、爱范儿、AppSo 等渠道发布,我们会注明来源和作者姓名。

        非常感谢~~~

      本文标题:微信小程序——gulp处理文件

      本文链接:https://www.haomeiwen.com/subject/hkgvittx.html