zoukankan      html  css  js  c++  java
  • gulp + gulp-better-rollup + rollup 构建 ES6 开发环境

    gulp + gulp-better-rollup + rollup 构建 ES6 开发环境

    关于 Gulp 就不过多啰嗦了。常用的 js 模块打包工具主要有 webpackrollupbrowserify 三个,Gulp 构建 ES6 开发环境通常需要借助这三者之一来合并打包 ES6 模块代码。因此,Gulp 构建 ES6 开发环境的方案有很多,例如:webpack-stream、rollup-stream 、browserify等,本文讲述使用 gulp-better-rollup 的构建过程。gulp-better-rollup 可以将 rollup 更深入地集成到Gulps管道链中。

    GitHub地址:https://github.com/JofunLiang/gulp-translation-es6-demo

    构建基础的 ES6 语法转译环境

    首先,安装 gulp 工具,命令如下:

    $ npm install --save-dev gulp

    安装 gulp-better-rollup 插件,由于 gulp-better-rollup 需要 rollup 作为依赖,因此,还要安装 rollup 模块和 rollup-plugin-babel(rollup 和 babel 之间的无缝集成插件):

    $ npm install --save-dev gulp-better-rollup rollup rollup-plugin-babel

    安装 babel 核心插件:

    $ npm install --save-dev @babel/core @babel/preset-env

    安装完成后,配置 .babelrc 文件和 gulpfile.js文件,将这两个文件放在项目根目录下。

    新建 .babelrc 配置文件如下:

    {
      "presets": [
        [
          "@babel/env",
          {
            "targets":{
              "browsers": "last 2 versions, > 1%, ie >= 9"
            },
            "modules": false
          }
        ]
      ]
    }

    新建 gulpfile.js 文件如下:

    const gulp = require("gulp");
    const rollup = require("gulp-better-rollup");
    const babel = require("rollup-plugin-babel");
    
    gulp.task("babel", () => {
      return gulp.src("src/**/*.js")
        .pipe(rollup({
          plugins: [babel()]
        },{
          format: "iife"
        }))
        .pipe(gulp.dest("dist"))
    })
    
    gulp.task("watch", () => {
        gulp.watch("src/**/*.js", gulp.series("babel"))
    })
    
    gulp.task("default", gulp.series(["babel", "watch"]))

    在 src 目录下使用 ES6 语法新建 js 文件,然后运行 gulp 默认任务,检查 dist 下的文件是否编译成功。

    使用 ployfill 兼容

    经过上面的构建过程,成功将 ES6 语法转译为 ES5 语法,但也仅仅是转换的语法,新的 api(如:Set、Map、Promise等) 并没有被转译。关于 ployfill 兼容可以直接在页面中引入 ployfill.js 或 ployfill.min.js 文件实现,这种方式比较简单,本文不再赘述,下面讲下在构建中的实现方式。

    安装 @babel/plugin-transform-runtime 、@babel/runtime-corejs2 和 core-js@2(注意:core-js的版本要和@babel/runtime的版本对应,如:@babel/runtime-corejs2对应core-js@2)。@babel/plugin-transform-runtime 的作用主要是避免污染全局变量和编译输出中的重复。@babel/runtime(此处指@babel/runtime-corejs2)实现运行时编译到您的构建中。

    $ npm install --save-dev @babel/plugin-transform-runtime @babel/runtime-corejs2 core-js@2

    修改 .babelrc 文件:

    {
      "presets": [
        [
          "@babel/env",
          {
            "targets":{
              "browsers": "last 2 versions, > 1%, ie >= 9"
            },
            "modules": false
          }
        ]
      ],
      "plugins": [
        [
          "@babel/plugin-transform-runtime", {
            "corejs": 2
          }
        ]
      ]
    }

    同时修改 gulpfile.js 文件,给 rollup-plugin-babel 配置 runtimeHelpers 属性如下:

    const gulp = require("gulp");
    const rollup = require("gulp-better-rollup");
    const babel = require("rollup-plugin-babel");
    
    gulp.task("babel", () => {
      return gulp.src("src/**/*.js")
        .pipe(rollup({
          plugins: [
            babel({
              runtimeHelpers: true
            })
          ]
        },{
          format: "iife"
        }))
        .pipe(gulp.dest("dist"))
    })
    
    gulp.task("watch", () => {
        gulp.watch("src/**/*.js", gulp.series("babel"))
    })
    
    gulp.task("default", gulp.series(["babel", "watch"]))

    再安装 rollup-plugin-node-resolve 和 rollup-plugin-commonjs,这两个插件主要作用是注入 node_modules 下的基于 commonjs 模块标准的模块代码。在这里的作用主要是加载 ployfill 模块。

    $ npm install --save-dev rollup-plugin-node-resolve rollup-plugin-commonjs

    在修改 gulpfile.js 文件如下:

    const gulp = require("gulp");
    const rollup = require("gulp-better-rollup");
    const babel = require("rollup-plugin-babel");
    const resolve = require("rollup-plugin-node-resolve");
    const commonjs = require("rollup-plugin-commonjs");
    
    gulp.task("babel", () => {
      return gulp.src("src/**/*.js")
        .pipe(rollup({
          plugins: [
            commonjs(),
            resolve(),
            babel({
              runtimeHelpers: true
            })
          ]
        },{
          format: "iife"
        }))
        .pipe(gulp.dest("dist"))
    })
    
    gulp.task("watch", () => {
        gulp.watch("src/**/*.js", gulp.series("babel"))
    })
    
    gulp.task("default", gulp.series(["babel", "watch"]))

    使用 sourcemaps 和压缩

    注意压缩使用 rollup-plugin-uglify 插件,为了提升打包速度,我们把模块文件放到 src/js/modules 文件夹下,将 gulp.src("src/js/.js") 改为 gulp.src("src/js/.js") 只打包主文件不打包依赖模块。

    安装 gulp-sourcemaps 和 rollup-plugin-uglify 插件:

    npm install --save-dev gulp-sourcemaps rollup-plugin-uglify 

    修改 gulpfile.js 文件如下:

    const gulp = require("gulp");
    const rollup = require("gulp-better-rollup");
    const babel = require("rollup-plugin-babel");
    const resolve = require("rollup-plugin-node-resolve");
    const commonjs = require("rollup-plugin-commonjs");
    const uglify = require("rollup-plugin-uglify");
    const sourcemaps = require("gulp-sourcemaps");
    
    gulp.task("babel", () => {
      return gulp.src("src/js/*.js")
        .pipe(sourcemaps.init())
        .pipe(rollup({
          plugins: [
            commonjs(),
            resolve(),
            babel({
              runtimeHelpers: true
            }),
            uglify.uglify()
          ]
        },{
          format: "iife"
        }))
        .pipe(sourcemaps.write('./'))
        .pipe(gulp.dest("dist/js"))
    })
    
    gulp.task("watch", () => {
        gulp.watch("src/**/*.js", gulp.series("babel"))
    })
    
    gulp.task("default", gulp.series(["babel", "watch"]))
  • 相关阅读:
    「七天自制PHP框架」第四天:模型关联
    「七天自制PHP框架」第三天:PHP实现的设计模式
    「七天自制PHP框架」第二天:模型与数据库
    一个例子简要说明include和require的区别
    解读Laravel,看PHP如何实现Facade?
    Laravel是怎么实现autoload的?
    Laravel表单提交
    Laravel的console使用方法
    PHP控制反转(IOC)和依赖注入(DI)
    PHP解耦的三重境界(浅谈服务容器)
  • 原文地址:https://www.cnblogs.com/jofun/p/10787826.html
Copyright © 2011-2022 走看看