首页 > 其他分享 >一份gulp的配置文件

一份gulp的配置文件

时间:2022-11-28 20:32:37浏览次数:76  
标签:src dist pipe 配置文件 js gulp Config 一份


参考:

优先参考:​​Getting started with gulp​

​Gulp安装及配合组件构建前端开发一体化​

​​用gulp-livereload实现浏览器自动刷新页面​​

gulpfile.js如下:


/**
* Created by admin on 2016/12/3.
*/

/**
* 组件安装
* npm install gulp gulp-notify gulp-livereload gulp-sass gulp-rename gulp-autoprefixer gulp-cssnano jshint gulp-jshint gulp-uglify gulp-concat gulp-imagemin del --save-dev
*
* 参考:
* http://www.dbpoo.com/getting-started-with-gulp/
* https://markgoodyear.com/2014/01/getting-started-with-gulp/
* javascript:void(0)
*/

// 引入 gulp及组件
var gulp = require('gulp'), //基础库
notify = require('gulp-notify'), //通知

//tinylr = require('tiny-lr'), //livereload
//server = tinylr(),
//port = 35729,
livereload = require('gulp-livereload'), //livereload

sass = require('gulp-sass'), //sass
rename = require('gulp-rename'), //重命名
autoprefixer = require('gulp-autoprefixer'), // 处理css中浏览器兼容的前缀
cssnano = require('gulp-cssnano'), // css的层级压缩合并

jshint = require('gulp-jshint'), //js检查 ==> npm install --save-dev jshint gulp-jshint(.jshintrc:https://my.oschina.net/wjj328938669/blog/637433?p=1)
uglify = require('gulp-uglify'), //js压缩
concat = require('gulp-concat'), //合并文件

imagemin = require('gulp-imagemin'), //图片压缩

del = require('del'); //清空文件


var SRC_DIR = './src/'; // 源文件目录
var DIST_DIR = './dist/'; // 文件处理后存放的目录
var DIST_FILE = DIST_DIR + '**'; // 目标路径下的所有文件

var Config = {
html: {
src: SRC_DIR + '*.html',
dist: DIST_DIR
},
assets: {
src: SRC_DIR + 'assets/**/*', // assets目录:./src/assets
dist: DIST_DIR + 'assets' // assets文件build后存放的目录:./dist/assets
},
css: {
src: SRC_DIR + 'css/**/*.css', // CSS目录:./src/css/
dist: DIST_DIR + 'css' // CSS文件build后存放的目录:./dist/css
},
sass: {
src: SRC_DIR + 'scss/**/*.scss', // SCSS目录:./src/scss/
dist: DIST_DIR + 'css' // SCSS文件生成CSS后存放的目录:./dist/css
},
js: {
src: SRC_DIR + 'js/**/*.js', // JS目录:./src/js/
dist: DIST_DIR + 'js', // JS文件build后存放的目录:./dist/js
build_name: 'build.js' // 合并后的js的文件名
},
img: {
src: SRC_DIR + 'images/**/*', // images目录:./src/images/
dist: DIST_DIR + 'images' // images文件build后存放的目录:./dist/images
}
};

/**
* copy任务(复制不需要处理的文件到dist目录下)
*/
/*var copyTasks = [
'html', 'assets'
]; // 定义单纯的复制功能的列表
gulp.task('copy', function () {
for (var i = 0; i < copyTasks.length; i++) {
var key = copyTasks[i];
gulp.src(Config[key].src)
.pipe(gulp.dest(Config[key].dist));
//.pipe(notify({ message: key + ' task complete' }));
}
});*/

/**
* HTML处理
*/
gulp.task('html', function () {
gulp.src(Config.html.src)
.pipe(gulp.dest(Config.html.dist));
});

/**
* assets文件夹下的所有文件处理
*/
gulp.task('assets', function () {
gulp.src(Config.assets.src)
.pipe(gulp.dest(Config.assets.dist));
});

/**
* CSS样式处理
*/
gulp.task('css', function () {
gulp.src(Config.css.src)
.pipe(autoprefixer('last 2 version'))
.pipe(gulp.dest(Config.css.dist))
.pipe(rename({suffix: '.min'}))
.pipe(cssnano()) //执行压缩
.pipe(gulp.dest(Config.css.dist))
.pipe(notify({message: 'css task complete'}));
});
/**
* 监听CSS文件的变化,变化后将执行CSS任务
*/
gulp.task('css-watch', function () {
gulp.watch(Config.css.src, ['css']);
});

/**
* SCSS样式处理
*/
gulp.task('sass', function () {
return gulp.src(Config.sass.src)
.pipe(autoprefixer('last 2 version'))
.pipe(sass())
.pipe(gulp.dest(Config.sass.dist))
.pipe(rename({suffix: '.min'})) //rename压缩后的文件名
.pipe(cssnano()) //执行压缩
.pipe(gulp.dest(Config.sass.dist))
.pipe(notify({message: 'sass task complete'}));
});
/**
* 监听SASS文件的变化,变化后将执行SASS任务
*/
gulp.task('sass-watch', function () {
gulp.watch(Config.sass.src, ['sass']);
});

/**
* js处理
*/
gulp.task('js', function () {
gulp.src(Config.js.src)
.pipe(jshint('.jshintrc'))
.pipe(jshint.reporter('default'))
.pipe(gulp.dest(Config.js.dist))
.pipe(rename({suffix: '.min'}))
.pipe(uglify())
.pipe(gulp.dest(Config.js.dist))
.pipe(notify({message: 'js task complete'}));
});
/**
* 合并所有js文件并做压缩处理
*/
gulp.task('js-concat', function () {
gulp.src(Config.js.src)
.pipe(jshint('.jshintrc'))
.pipe(jshint.reporter('default'))
.pipe(concat(Config.js.build_name))
.pipe(gulp.dest(Config.js.dist))
.pipe(rename({suffix: '.min'}))
.pipe(uglify())
.pipe(gulp.dest(Config.js.dist))
.pipe(notify({message: 'js-concat task complete'}));
});

/**
* 图片处理
*/
gulp.task('images', function () {
return gulp.src(Config.img.src)
.pipe(imagemin({optimizationLevel: 3, progressive: true, interlaced: true}))
.pipe(gulp.dest(Config.img.dist))
/*.pipe(notify({ message: 'images task complete' }))*/;
});

/**
* 清空图片、样式、js
*/
gulp.task('clean', function () {
return del([Config.html.dist, Config.css.dist, Config.js.dist, Config.img.dist]);
});
gulp.task('clean-all', function () {
return del([Config.html.dist, Config.assets, Config.css.dist, Config.js.dist, Config.img.dist]);
});

/**
* 默认任务 清空图片、样式、js并重建 运行语句 gulp
*/
gulp.task('default', ['clean'], function () {
gulp.start('html', 'assets', 'css', 'images', 'js');
});


/**
* 监听任务
*/
gulp.task('watch', function () {
// Watch .html files
gulp.watch(Config.html.src, ['html']);

// Watch .css files
gulp.watch(Config.css.src, ['css']);

// Watch .scss files
gulp.watch(Config.sass.src, ['sass']);

// Watch assets files
gulp.watch(Config.assets.src, ['assets']);

// Watch .js files
gulp.watch(Config.js.src, ['js']);

// Watch image files
gulp.watch(Config.img.src, ['images']);

// Create LiveReload server
livereload.listen();

// Watch any files in dist/, reload on change
gulp.watch([DIST_FILE]).on('change', livereload.changed);
});


项目目录参考结构如下:

一份gulp的配置文件_前端开发

从上面的目录结果可以看到,除了有package.json和gulp配置文件gulpfile.js外,还有一个 .jshintrc 文件。这个是插件 gulp-jshint 校验js使用的。(网上找了一份,参考地址见gulpfile.js中的注释部分)

.jshintrc如下:

{

"es5": true,
"node": true,

"bitwise": false,

"camelcase": false,

"curly": false,

"eqeqeq": false,

"forin": true,

"strict": false,

"freeze": true,

"immed": true,

"indent": 4,

"latedef": true,

"newcap": true,

"noarg": true,

"noempty": false,

"nonbsp": true,

"nonew": true,

"plusplus": false,

"undef": true,

"trailing": true,

"debug": false,

"funcscope": true,

"laxcomma": false,

"loopfunc": true,

"onevar": false,

"unused": true

}

使用cmd命令进入当前项目目录,使用gulp watch 即可启动gulp监听项目文件,文件修改时,对应gulp任务就会被触发并执行。

使用gulp-livereload插件可以实现文件修改时浏览器的自动刷新,需要在服务器环境下,推荐使用 通过npm安装​​http-server​​,快速建立http服务。

参考如下:


LiveReload配置

1、安装Chrome ​​LiveReload​​​ 2、通过npm安装​​http-server​​,快速建立http服务

npm install http-server -g

3、通过cd找到发布环境目录dist
4、运行http-server,默认端口是8080
5、访问路径localhost:8080
6、再打开一个cmd,通过cd找到项目路径执行gulp,清空发布环境并初始化
7、执行监控 gulp
8、点击chrome上的LiveReload插件,空心变成实心即关联上,你可以修改css、js、html即时会显示到页面中。



标签:src,dist,pipe,配置文件,js,gulp,Config,一份
From: https://blog.51cto.com/u_15894233/5893657

相关文章

  • 写一份gulp常用配置文件,构建前端工作流
    目录​​目录​​​​前言​​​创建项目​​​初始化项目​​​​创建目录结构​​​编写Gulp配置​​​创建gulp的config文件​​​​创建gulp的dev文件​​​​创建gulp......
  • log4j2配置文件
    log4j2.xml(ps:固定名称)<?xmlversion="1.0"encoding="UTF-8"?><!--日志级别以及优先级排序:OFF>FATAL>ERROR>WARN>INFO>DEBUG>TRACE>ALL--><!--Configu......
  • gulp构建工具的几个使用技巧
        这里并不讲什么gulp及其其插件的安装,此前的文章已经提到过了。这里主要用来记录一下,gulp构建工具的一些简单常用的用法。​​最有用的Gulp插件汇总​​1)假如我......
  • 想体验ES6语法?那用gulp+Babel来搭建ES6环境吧~
    参考:​​ES6初体验——gulp+Babel搭建ES6环境​​​​gulp-load-plugins模块化管理插件​​那至于怎么使用gulp构建工具这一问题这里就略过咯(可以参考我之前发过的......
  • 010Prometheus配置文件中metric_relabel_configs详解
    Prometheus从数据源拉取数据后,会对原始数据进行编辑其中 ​​metric_relabel_configs​​​是Prometheus在保存数据前的最后一步标签重新编辑(relabel_configs)。所以,哪......
  • 十一月第一份阅读笔记
    本次阅读了程序员修炼之道:从小工到专家的第五章,第五章弯曲,或折断主要包括了五个小章节:解耦与得墨忒耳法则,元程序设计,时间耦合,它只是视图,黑板。耦合即代码模块间的依赖关系......
  • .net 升级 NetCore Config配置文件 读取
    .netConfigurationManager.AppSettings[key];读取配置文件,依赖于.netframework库,当升级为.netcore时会读不到,此时.netcore读取配置文件,可以直接通过读取xml节点......
  • win10无法加载用户配置文件,无法返回主用户
    在一次捣鼓电脑的过程中,需要新建一个用户,老规矩输入命令新建netuser{username}{password}/add切换用户登录后显示无法加载用户配置文件不仅登录不进去了,就连原来......
  • PropertyPlaceholderConfigurer、PropertyOverrideConfigurer等对属性配置文件Propert
    Spring的PropertyResourceConfigurer是个抽象类,继承自PropertiesLoaderSupport,并实现了接口BeanFactoryPostProcessor。注意:它是个Bean工厂的后置处理器,而不是Bean的后置......
  • application、nacos和各个配置文件生效顺序
    平常Java开发中会用到好多配置文件,比如application、bootstrap、nacos文件等下面就来说一下生效顺序nacos>application-dev.yaml>application.yaml>bootstrap.yaml......