使用gulp+bebal实现前端自动化es6转es5的构建
说明:es6语法已经越来越普及,但是一些低版本的浏览器不支持es6的语法特性,所以我们在开发完前端项目后,往往需要统一把前端es6的代码编译成es5的代码。本文介绍的就是如何手动和自动的把es6转成es5的方法。本文前提:需要提前安装好nodejs环境,能够使用npm命令。如果不了解如果配置npm,可以查看笔者前几次的博文。
使用babel来手动构建es5的方式:
1、创建一个空的前端项目
可以使用webStorm等前端工具创建一个空的项目即可。
并创建src/main.js,文件内容如下,其中使用了es6语法胖箭头函数:
(()=>{ console.log(es6 test !); })();
2、创建npm的配置文件package.json
项目根目录下创建package.json文件,里面只写一个{}即可:
{}
3、安装babel-cli
babel-cli可以把es6语法转成大多数浏览器所能识别的es5语法。
在项目根目录下执行:
$ npm install babel-cli --save-dev
执行后,项目中会自动创建node_modules文件夹;
package.json文件中会产生devDependencies节点,节点中会有“babel-cli”字样的属性。
4、下载es2015解释器
如果要构建到es5语法,就需要下载es2015的解释器,执行:
$ npm install babel-preset-es2015 --save-dev
执行后,package.json文件devDependencies节点中会创建"babel-preset-es2015"字样的属性。
5、创建babel的配置文件
项目中创建.babelrc文件,内容:
{"presets" : [["es2015"]]}
6,创建npm build命令
在package.json文件增加script节点,表示可以使用npm run build命令执行以下语句
"script" : { "build" : "babel src -d assets/js" }
6、构建
$ npm run build
执行后,项目中会产生assets/js/main.js文件,里面内容就是es5语法了,内容:
"use strict"; (function()(){ console.log(es6 test !); })();
使用gulp + babel 自动化构建方法:
1、安装gulp
执行以下两句。分别是全局安装和本地安装。
说明:如果是自己项目使用,第一个全局安装就可以了;但是本地安装可以方便与其他人拷贝走项目后,其他人就不需要自己安装gulp就能编译工程了
$ npm install gulp-cli --global $ npm install gulp --save-dev
2、安装gulp-babel
gulp-babel是gulp和babel集成的工具。执行以下:
$ npm install gulp-babel --save-dev
3、配置gulp配置文件
项目根目录下创建gulpfile.js。
const gulp = require('gulp'); const gulp = require('gulp-babel'); gulp.task('default', ['babel']); gulp.task('babel', function(){ return gulp.src('src/*.js') .pipe(babel({ presets : ['es2015'] })) .pipe(gulp.desc('assets/js')) })
然后每次执行一下以下命令就可以实现编译了,执行后会把编译后的js文件放在项目中的assets/js文件夹下,
$ gulp
4、实现实时编译
改造gulpfile.js,如下:
const gulp = require('gulp'); const gulp = require('gulp-babel'); gulp.task('default', ['watch']); gulp.task('babel', function(){ return gulp.src('src/*.js') .pipe(babel({ presets : ['es2015'] })) .pipe(gulp.desc('assets/js')) }); gulp.task('watch', function(){ gulp.watch('src/*.js', ['babel']); });
然后打开项目后执行一次以下命令即可,gulp就会监听工程,每次js有变化都会自动的实时编译。
$ gulp
当然,如果不想实时编辑,执行手动编辑,执行 $ gulp babel 也可。
使用gulp+bebal实现前端自动化es6转es5的构建的更多相关文章
- gulp自动化ES6转ES5
npm install --save-dev gulp npm install --save-dev gulp-babel npm install --save-dev babel-preset-es ...
- gulp详细教程——前端自动化构建工具
项目构建 一个项目是由多个开发者共同开发一个项目,各负责不同的模块,这就会造成一个完整的项目许多‘代码片段’组成,合并css.javascript,压缩html.css.javascript.imag ...
- 前端自动化构建工具 Gulp 使用
一个月没写博客了,今天有时间,就写个gulp的入门使用吧.. 简介:gulp是一个前端自动化构建工具,可以实现代码的检查.压缩.合并……等等,gulp是基于Node.js的自动任务运行器 一.安装No ...
- 【前端自动化】Gulp的使用(一):安装gulp
作为一个.NET码农,在前端高速发展的时代,深深感觉自己那么点“前端”技术不够看,比如开发出来的js css等文件庞大,不便于管理,还记得以前的开发就是累加 html css jquery, 现 ...
- 前端自动化gulp遇上es6从 无知到深爱
Gulp是什么? Gulp是前端自动化的工具,但Gulp能用来做什么 1.搭建web服务器 2.使用预处理器Sass,Less 3.压缩优化,可以压缩JS CSS Html 图片 4.自动将更新变化的 ...
- 前端自动化工具gulp自动添加版本号
之前,我介绍了学习安装并配置前端自动化工具Gulp,觉得gulp确实比grunt的配置简单很多,于是我决定再深入学习一下gulp,就去网上查了资料,发现gulp还可以自动添加版本号,这个功能就为我平时 ...
- 构建一个基本的前端自动化开发环境 —— 基于 Gulp 的前端集成解决方案(四)
通过前面几节的准备工作,对于 npm / node / gulp 应该已经有了基本的认识,本节主要介绍如何构建一个基本的前端自动化开发环境. 下面将逐步构建一个可以自动编译 sass 文件.压缩 ja ...
- 前端自动化构建工具gulp记录
一.安装 1)安装nodejs 通过nodejs的npm安装gulp,插件也可以通过npm安装.windows系统是个.msi工具,只要一直下一步即可,软件会自动在写入环境变量中,这样就能在cmd命令 ...
- 学习安装并配置前端自动化工具Gulp
Gulp和所有Gulp插件都是基于nodeJs来运行的,因此在你的电脑上需要安装nodeJs,安装过程请移驾安装并配置前端自动化工具--grunt.安装完成后,通过运行cmd进入DOS命令窗口,如图: ...
随机推荐
- C++学习基础十六-- 函数学习笔记
C++ Primer 第七章-函数学习笔记 一步一个脚印.循序渐进的学习. 一.参数传递 每次调用函数时,都会重新创建函数所有的形参,此时所传递的实参将会初始化对应的形参. 「如果形参是非引用类型,则 ...
- sybase-sql语法-replace用法
1.去空格 update hyl_temp02 --去空格 set acc_nbr=replace(acc_nbr,' ',''); commit; 2.去回车 update hyl_temp02 - ...
- suse linux安装lrzsz
1.从下面的网站下载 lrzsz-1.12.20.tar.gz http://www.filewatcher.com/m/lrzsz-0.12.20.tar.gz.280938.0.0.html 2. ...
- get_time
def get_current_time(): #将python的datetime转换为unix时间戳 dtime = datetime.datetime.now() un_time = time.m ...
- html迪士尼网页实现代码
html body> <div> <!-- 导航设置 --> <header> <nav ...
- NYOJ252-01串-(数位dp)
252-01串 内存限制:64MB 时间限制:1000ms 特判: No通过数:33 提交数:49 难度:2 题目描述: ACM的zyc在研究01串,他知道某一01串的长度,但他想知道不含有“11”子 ...
- MQ队列堵塞无法读取经验总结
问题现象: 1号发生本地来帐队列无法读取消息的问题,导致来帐报文均无法正常处理. 原因分析: 应用系统没有修改或上包,昨天交易和消息读取还是一切正常,mbfe的状态也是正常,mq的状态正常,以上正常可 ...
- nginx-web身份验证
1.配置文件设置: server { listen 80; server_name www.longshuai.com www1.longshuai.com; location / { root /w ...
- vue项目强制清除页面缓存
异常描述: 支付宝中内嵌h5项目(vue框架开发),前端重新打包上传之后访问页面会导致页面空白.页面tab点击异常之类异常情况,需要手动清除支付宝缓存才可以正常访问. 解决方案: 在HTTP协议中,只 ...
- 289. Game of Life数组生存游戏
[抄题]: According to the Wikipedia's article: "The Game of Life, also known simply as Life, is a ...