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

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. Linux服务器下jdk 安装与环境变量的配置

    1,Oracle 官网下载jdk Linux版本 https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-213 ...

  2. 什么是Unicode

    写这篇博客的原因, 从做软件开始,什么ASCII码, Unicode,UTF-8,UTF-16,UTF-32......这些鬼东西总是经常碰到,只知道这些鬼是编码格式,其他的就啥都不清楚了,既然总是遇 ...

  3. DataBase(28)

    1.数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立.使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完 ...

  4. php中生成标准uuid(guid)的方法

    );// "}"        return $uuid;    }}echo guid();?>

  5. var_dump()函数输出不完整,有省略号?解决办法

    php开发环境里,安装了xdebug模块后,var_dump()输出的结果将比较易于查看,但默认情况下,var_dump() 输出的结果将有所变化:过多的数组元素不再显示,字符串变量将只显示前N个字符 ...

  6. 前端框架VUE----对象的单体模式

    对象的单体模式 为了解决箭头函数this指向的问题 推出来一种写法 对象的单体模式 1 var person = { 2 name:'小马哥', 3 age:12, 4 fav(){ 5 consol ...

  7. node.js的on、emit、off封装

    //绑定事件.触发事件和移除事件 //绑定事件 //on(eventName,cb){} //第一步判断当前事件是否存在,如果不存在则初始化:key:[],然后在将回调函数添加到数据中去 let ev ...

  8. react复习总结(2)--react生命周期和组件通信

    这是react项目复习总结第二讲, 第一讲:https://www.cnblogs.com/wuhairui/p/10367620.html 首先我们来学习下react的生命周期(钩子)函数. 什么是 ...

  9. lnmp vhost 文件

    server { listen 80 default_server; #listen [::]:80 default_server ipv6only=on; server_name blog.yang ...

  10. Mysql 批量更新update的表与表之间操作

    Mysql 批量更新update的表与表之间操作 一.方法一 使用User2表数据更新User表: update User as a ,User2 as b set a.role_id=b.set_v ...