首先老规矩哈、全局包安装先

cnpm install webpack  -g

cnpm install gulp -g

cnpm install babel  -g //转换Es6

上面的整合在一起安装可以写在一起  如下

cnpm install webpack  gulp babel  -g

gulpfile.js   gulp的配置文件

var gulp        = require('gulp'),
browserSync = require('browser-sync').create(),
plugins = require('gulp-load-plugins')(), //自动加载插件的插件,之后就可以不直接引用插件
reload = browserSync.reload,
spritesmith = require('gulp.spritesmith'),//合并雪碧图
babel = require("gulp-babel"), //转编成Es6
plumber = require("gulp-plumber"),//编译时出错不会终止gulp,结合gulp-notify使用可以弹窗提醒
notify = require("gulp-notify"),//为gulp-plumber 报错提供弹窗
webpack = require('webpack-stream'), //引入webpack
named = require('vinyl-named'); //输出时对应webpack的文件名 防止输出hash值 /************先不压缩css,js,开发完在进行压缩,这样便于调试***************/
// 引入webpack
gulp.task('webpack', function(){
return gulp.src('webpackDemo/*js')
.pipe(plumber({errorHandler: notify.onError({title: '小智哥编译出错啦',message: '<%=error%>'})}))
.pipe(named())
.pipe(webpack(require("./webpack.config.js")))
.pipe(gulp.dest('webpackPage/'));
});
// 转译Es6
gulp.task('Es6',function(){
return gulp.src('src/es6/*js')
.pipe(plumber({errorHandler: notify.onError({title: '小智哥编译出错啦',message: '<%=error%>'})})) //有时候失效
.pipe(babel({presets: ['es2015']}))
.pipe(plugins.uglify()) //压缩js
.pipe(gulp.dest('dist/es6/'));
}) // scss编译后的css将注入到浏览器里实现更新
gulp.task('sass', function() {
return gulp.src('src/sass/*.scss')//引入要编译的文件目录
.pipe(plumber({errorHandler: notify.onError({title: '小智哥编译出错啦',message: '<%=error%>'})}))
.pipe(plugins.sass()) //编译sass
.pipe(plugins.cleanCss()) //压缩编译后的css
.pipe(gulp.dest('dist/css/')) //输出目录
.pipe(reload({stream: true})); //browserSync的同步处理状态
}); // 压缩js
gulp.task('compressJs',function(){
return gulp.src('src/js/*js')
.pipe(plumber({errorHandler: notify.onError({title: '小智哥编译出错啦',message: '<%=error%>'})}))
.pipe(plugins.uglify()) //压缩js
.pipe(gulp.dest('dist/js/'));
}) // 公用的css处理
gulp.task('publicCss',function(){
return gulp.src('src/publicCss/*css') //压缩公用的css
.pipe(plugins.cleanCss()) //压缩编译后的css
.pipe(gulp.dest('dist/publicCss/')); //输出目录
}) //压缩img
gulp.task('compressImg', function (){
return gulp.src('src/images/*.{jpg,png}')
// .pipe(plugins.smushit()) //等项目开发完再压缩图片,因为压缩图片很费时间
.pipe(gulp.dest('dist/images/'));
}); // 生成雪碧图
gulp.task('spriteImg', function () {
return gulp.src('src/spriteImg/*.png')//需要合并的图片地址
.pipe(spritesmith({
imgName: 'spriteImg.png',//保存合并后图片的地址
cssName: 'sprite.css',//保存合并后对于css样式的地址
padding:5,//合并时两个图片的间距
algorithm: 'binary-tree',//默认位置,现在市值为左边开始
cssTemplate: function (data) { //cssTemplate 是生成css的模板文件可以是字符串也可以是函数。下面以js函数为例子
var arr=[];
data.sprites.forEach(function (sprite){
arr.push(".icon-"+sprite.name+
"{" +
"background-image: url('"+sprite.escaped_image+"');"+
"background-position: "+sprite.px.offset_x+" "+sprite.px.offset_y+";"+
"width:"+sprite.px.width+";"+
"height:"+sprite.px.height+";"+
"}\n");
});
return arr.join("");
}
}))
.pipe(gulp.dest('dist/spriteImg'));
}); // 静态服务器 + 监听 scss/html 文件
gulp.task('serve', ['sass','Es6','compressJs','webpack','publicCss','compressImg','spriteImg'], function() {
browserSync.init({
server: {
    baseDir: "./", //默认的文件打开入口
    // index:'banner.html' //自定义的打开入口
    },
open:false,//停止自动打开浏览器
port: 9000, //修改端口
ui:{port: 9001}// 后台ui的设置,里面可以设置页面是否联动,默认是联动的
});
// 监控webpack
gulp.watch('webpackDemo/*.js', ['webpack']); //执行webpack
gulp.watch('webpackPage/*.js').on('change',reload); //执行webpack后监控它执行的目标文件,有变化则刷新页面
// 雪碧图
gulp.watch('src/spriteImg/*.png', ['spriteImg']); //执行sprite
gulp.watch('dist/spriteImg').on('change',reload); //执行sprite后监控它执行的目标文件,有变化则重新生成雪碧图
// 监听Es6
gulp.watch('src/es6/*.js', ['Es6']); //执行Es6
gulp.watch('dist/es6/*.js').on('change',reload); //执行Es6后监控它执行的目标文件,有变化则刷新页面
// 监听根目录html
gulp.watch("./*.html").on('change',reload); //监控html 只能在根目录
// 监听sass
gulp.watch('src/sass/*.scss',['sass']); //开启了browserSync监控就执行sass
gulp.watch("dist/css/*.css").on('change',reload); //执行sass后监控它生成的目标文件,有变化就刷新页面
//公用的css
gulp.watch('src/publicCss/*.css',['publicCss']);
gulp.watch('dist/publicCss/*.css').on('change',reload);
//监听js
gulp.watch('src/js/*js', ['compressJs']); //开启了browserSync监控就执行 compressJs
gulp.watch('dist/js/*.js').on('change',reload); //监控引入的js当js改变页面也同时进行
// 执行压缩img
gulp.watch('src/images/*.{jpg,png}',['compressImg']); //开启了browserSync监控就执行 compressImg
gulp.watch('dist/images/*.{jpg,png}').on('change',reload); });
gulp.task('default', ['serve']); //gulp 默认执行同步指令

webpack.config.js    webpack的配置文件

var webpack = require('webpack');
module.exports={
module:{
loaders:[
{ test:/\.css$/,//匹配.css文件
loader:'style-loader!css-loader'//用style-loader去解释css
}
]
},
plugins: [
new webpack.optimize.UglifyJsPlugin({compress: {warnings: false} }) //自动输出压缩后的js,css
]
}

下面是package.json的依赖包列表

{
"scripts": {
"xz": "gulp"
},
"devDependencies": {
"babel-preset-es2015": "^6.24.1",
"browser-sync": "^2.18.12",
"css-loader": "^0.28.4",
"gulp": "^3.9.1",
"gulp-babel": "^6.1.2",
"gulp-clean-css": "^3.4.2",
"gulp-load-plugins": "^1.5.0",
"gulp-notify": "^3.0.0",
"gulp-plumber": "^1.1.0",
"gulp-sass": "^2.3.2",
"gulp-smushit": "^1.2.0",
"gulp-uglify": "^3.0.0",
"gulp.spritesmith": "^6.5.1",
"style-loader": "^0.18.2",
"uglify-js": "^3.0.20",
"vinyl-named": "^1.1.0",
"webpack": "^3.0.0",
"webpack-stream": "^3.2.0"
}
}

gulp结合webpack开启多页面模式,配置如下的更多相关文章

  1. gulp + webpack 构建多页面前端项目

    修改增加了demo地址 gulp-webpack-demo 之前在使用gulp和webpack对项目进行构建的时候遇到了一些问题,最终算是搭建了一套比较完整的解决方案,接下来这篇文章以一个实际项目为例 ...

  2. Gulp和Webpack对比

    在现在的前端开发中,前后端分离.模块化开发.版本控制.文件合并与压缩.mock数据等等一些原本后端的思想开始逐渐渗透到“大前端”的开发中.前端开发过程越来越繁琐,当今越来越多的网站已经从网页模式进化到 ...

  3. Webpack + Vue 多页面项目升级 Webpack 4 以及打包优化

    0. 前言 早在 2016 年我就发布过一篇关于在多页面下使用 Webpack + Vue 的配置的文章,当时也是我在做自己一个个人项目时遇到的配置问题,想到别人也可能遇到跟我同样的问题,就把配置的思 ...

  4. webpack 构建多页面应用

    如何使用webpack构建多页面应用,这是一个我一直在想和解决的问题.网上也给出了很多的例子,很多想法.猛一看,觉得有那么点儿意思,但仔细看也就那样. 使用webpack这个构建工具,可以使我们少考虑 ...

  5. webpack从单页面到多页面

    前言 从上次更完webpack从什么都不懂到入门之后,好久没有更新过文章了,可能是因为自己懒了吧.今天看了下自己的索引量少了一半o(╥﹏╥)o,发现事态严重,赶紧更新一篇23333 也是因为最近踩了一 ...

  6. 使用gulp插件来自动刷新页面。

    http://itakeo.com/blog/2016/05/19/gulpreload/?none=123 使用gulp插件来自动刷新页面.再也不用修改一次,按一下F5了. 首选通过npm inst ...

  7. 前端开发自动化工作流工具,JavaScript自动化构建工具grunt、gulp、webpack介绍

    前端开发自动化工作流工具,JavaScript自动化构建工具grunt.gulp.webpack介绍 前端自动化,这样的一个名词听起来非常的有吸引力,向往力.当今时代,前端工程师需要维护的代码变得及为 ...

  8. Gulp和webpack的区别,是一种工具吗?

    疑问:gulp和webpack 什么关系,是一种东西吗?可以只用gulp,不用webpack吗 或者反过来? 它们的区别和概念 ------------------------------------ ...

  9. webpack开发与生产环境配置

    前言 作者去年就开始使用webpack, 最早的接触就来自于vue-cli.那个时候工作重点主要也是 vue 的使用,对webpack的配置是知之甚少,期间有问题也是询问大牛 @吕大豹.顺便说一句,对 ...

随机推荐

  1. wifi pj WiFiPhisher 安装使用

    1.安装kali linux: https://blog.csdn.net/qq_42545206/article/details/82788119 https://www.kali.org/down ...

  2. 转:【专题九】实现类似QQ的即时通信程序

    引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例来让大家更好的理解它们的工作原理以及怎样.Net类库去实现它们的.为了让大家更好的理解我们平常中常见的软件QQ的工作原理,所以在 ...

  3. 区块链公链分片技术(sharding)方案,配思维导图

    区块链公链分片技术(sharding)方案,配思维导图 分片技术(sharding)方案 以太坊分片思路 其基本思想是,将网络中的节点分成不同的碎片,各分片可以并行处理不同交易,这样可以并行处理相互之 ...

  4. 那个写书教你交易期权的人James Cordier爆仓了

    那个写书教你交易期权的人James Cordier爆仓了 11月15日,James Cordier掌管的期权交易公司OptionSellers.com通过邮件告知投资者,其公司管理的账户遭遇了毁灭性的 ...

  5. 案例:通过shell脚本实现mysql数据备份与清理

    Shell是系统的用户界面,提供了用户与内核进行交互操作的一种接口.它接收用户输入的命令并把它送入内核去执行,实际上Shell是一个命令解释器,它解释由用户输入的命令并且把它们送到内核,不仅如此,Sh ...

  6. Docker学习笔记之浅谈虚拟化和容器技术

    0x00 概述 相信所有对 Docker 有所耳闻的朋友都知道,它是一款以容器虚拟化技术为基础的软件,因此在了解有关 Docker 的概念知识和使用方法之前,虚拟化和容器技术是我们不可或缺的基础知识. ...

  7. Golang错误处理函数defer、panic、recover、errors.New介绍

    在默认情况下,当发生错误(panic)后,程序就会终止运行 如果发生错误后,可以捕获错误,并通知管理人员(邮件或者短信),程序还可以继续运行,这当然无可厚非 errors.New("错误信息 ...

  8. ElasticSearch vs Solr多维度分析对比

    福利 => 每天都推送 欢迎大家,关注微信扫码并加入我的4个微信公众号:   大数据躺过的坑      Java从入门到架构师      人工智能躺过的坑         Java全栈大联盟   ...

  9. P4316 绿豆蛙的归宿(期望)

    P4316 绿豆蛙的归宿 因为非要用bfs所以稍微麻烦一点qwq(大家用的都是dfs) 其实问题让我们求的就是经过每条边的概率*边权之和 我们可以用bfs把图遍历一遍处理概率,顺便把每条边的概率*边权 ...

  10. python简说(六)判断

    非空即真,非0即真True '1' [1] {k-v}False '' None [] {}