使用gulp实现文件压缩及浏览器热加载

一.安装gulp

  首先,你要安装过nodejs,如果没有安装过的同学请自行下载。  先再命令行里输入   npm install gulp -g   下载gulp

二.创建gulp项目

  创建一个你需要项目文件夹,然后在根目录输入  npm init  (npm init命令会为你创建一个package.json文件,这个文件保存着这个项目相关信息。比如你用到的各种依赖)

三.使用npm install 安装各种依赖

  例:npm install browser-sync--save-dev

  

  这里总共用到了这些依赖,请自行下载   具体各自都有什么用 后面会具体介绍。

四.编写gulpfile.js

  首先,声明这些依赖

  

  然后我们就要开始最重要的工作了,配置这些依赖

  1.配置压缩css

  

  2.配置压缩js

  

  3.配置压缩img

  

  4.配置html,这里没有进行压缩,感觉没有压缩的必要 (纯属见仁见智)

  

  5.配置清楚文件,因为每次打包都会生成新文件  所以在这之前要把之前的文件给清除掉

  

  6.配置浏览器热加载

  

  7.配置打包

  这里的runSequence是指能同时执行多个命令

  

  8.设置gulp启动时执行哪些配置

  

  最后放上全部代码 供大家参考

  

var gulp = require(‘gulp‘);
var sass = require(‘gulp-sass‘);
var browserSync = require(‘browser-sync‘);
var uglify = require(‘gulp-uglify‘);
var imagemin = require(‘gulp-imagemin‘);
var minifyCSS  = require(‘gulp-minify-css‘);
var cache = require(‘gulp-cache‘);
var del = require(‘del‘);
var runSequence = require(‘run-sequence‘);
var minifyHtml= require("gulp-minify-html");

gulp.task(‘sass‘, function(){   //打包sass
  return gulp.src(‘app/scss/**/*.scss‘)
    .pipe(sass()) // Converts Sass to CSS with gulp-sass
    .pipe(gulp.dest(‘app/css‘))
    .pipe(browserSync.reload({
      stream: true
    }))
});

gulp.task(‘js‘,function() {

    gulp.src(‘app/**/*.js‘)

    .pipe(uglify())//压缩

    .pipe(gulp.dest(‘dist‘));

});

gulp.task(‘css‘, function () {
    gulp.src(‘app/css/*.css‘)
    .pipe(minifyCSS())
    .pipe(gulp.dest(‘dist/css‘))
})

gulp.task(‘minify-html‘,function() {

      gulp.src(‘app/**/*.html‘)//要压缩的html文件
     .pipe(gulp.dest(‘dist‘));

});

gulp.task(‘images‘, function(){
  return gulp.src(‘app/images/**/*.+(png|jpg|jpeg|gif|svg)‘)
  // Caching images that ran through imagemin
  .pipe(cache(imagemin({
      interlaced: true
    })))
  .pipe(gulp.dest(‘dist/images‘))
});

gulp.task(‘clean‘, function(callback) {
  del(‘dist‘);
  return cache.clearAll(callback);
});

gulp.task(‘watch‘,[‘browserSync‘, ‘sass‘],function(){   //我们可以在watch任务之前告知Gulp,先把browserSync和Sass任务执行了再说。
  gulp.watch(‘app/scss/**/*.scss‘, [‘sass‘]);
  gulp.watch(‘app/*.html‘, browserSync.reload);
  gulp.watch(‘app/js/**/*.js‘, browserSync.reload);
  // Other watchers
});

gulp.task(‘browserSync‘, function() {  //浏览器热加载
  browserSync({
    server: {
      baseDir: ‘app‘
    },
  })
});

gulp.task(‘build‘, function (callback) {
  runSequence(‘clean‘,[‘minify-html‘,‘js‘,‘images‘,‘css‘],callback)
});

gulp.task(‘default‘, function (callback) {
  runSequence([‘sass‘,‘browserSync‘, ‘watch‘],
    callback
  )
});
时间: 2024-08-09 10:36:58

使用gulp实现文件压缩及浏览器热加载的相关文章

gitbook 入门教程之解决windows热加载失败问题

破镜如何贴花黄 gitbook 在 Windows 系统无法热加载,总是报错! gitbook 是一款文档编写利器,可以方便地 markdown 输出成美观优雅的 html ,gitbook serve 启动服务器后,原来相貌平平的 markdown 丑小鸭摇身一变就成了倾国倾城的 html 绝色佳人. 如果源文件发生更改,Windows 却无法按照预期那样重启服务器,直接抛出一个异常,立即终止了 markdown 的化妆. Restart after change in file README

前端工具-浏览器同步测试(自动刷新、热刷新、热加载)

Browsersync 官网:https://www.browsersync.io/ 中文:http://www.browsersync.cn/ Gulp中使用 http://www.browsersync.cn/docs/gulp/ 注意1:我测试哪个tesk在下面哪个好使(要么能使用静态服务器,要么用代理?)貌似不能部分请求用代理.. var gulp = require('gulp'); var browserSync = require('browser-sync').create();

webpack2 热加载js 文件

如果只要普通的热加载 只要如下配置就好了 package.json { "devDependencies": { "webpack": "^2.6.1", "webpack-dev-server": "^2.4.5" }, "scripts": { "start": "webpack-dev-server" } } webpack.config.j

xBIM 实战01 在浏览器中加载IFC模型文件

一.创建Web项目 打开VS,新建Web项目,选择 .NET Framework 4.5 选择一个空的项目 新建完成后,项目结构如下: 二.添加webServer访问文件类型 由于WexXplorer 加载的是 .wexBIM格式的文件或者文件流,所以需要在Web.config文件中添加如下配置 <system.webServer> <security> <requestFiltering> <requestLimits maxAllowedContentLeng

xBIM 实战02 在浏览器中加载IFC模型文件并设置特效

系列目录    [已更新最新开发文章,点击查看详细] 在模型浏览器中加载模型后,可以对模型做一些特殊操作.下图是常用的设置. 都是通过 xbim-viewer.js 中的 API 来设置以达到一定的效果.代码如下: 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <title>xViewer</title> 5 <meta http-equiv="content-type" content=&

[Eclipse] - 集成JBoss7热加载和自动发布

使用Eclipse + JBoss开发时,总是要重启项目或JBoss,烦人.下面方法可以很简单的实现Eclipse + JBoss热加载和自动发布. 我的环境是JBoss 7.1.1 Final 1) 下载这个:jboss-as-web-7.1.1.Final-RECOMPILE.jar http://files.cnblogs.com/HD/jboss-as-web-7.1.1.Final-RECOMPILE.jar.zip 2) 把这个jar包放到这个目录下:jboss-as-7.1.1.F

webpack+express实现“热更新”和“热加载”

"热更新":对应的是 'webpack-dev-middleware' 中间件 "热加载":对应的是 'webpack-hot-middleware' 中间件 为了使用这两个中间件,必须修改"webpack.config.js"和"server.js" webpack配置文件("webpack.config.js")和上一篇博文写的大致相同,下面给出一个vue+webpack开发常用的配置: const p

asp.net网站开发中用jquery实现滚动浏览器滚动条加载数据(类似于腾讯微博)

自从腾讯微博上线以来,基本上就开始用了,一直到现在,作为一个开发人员,也看到了腾讯微博一直在不停的改变,也不知道大家有没有发现,腾讯微博提供两种加载数据的方式,一种是分页,一种是滚动浏览器滚动条加载数据,分页功能我想大家都做得太多了,今天我与大家分享一下我用滚动条滚动加载数据,小生不才,还望各位大侠指教,呵呵~ 下面开讲: 首先说一下思路,我用的是Jquery,然后通过Jquery的ajax()方法通过 HTTP 请求加载远程数据来实现的,用到Jquery,首先要应用jquery.min.js类

mybatis热加载的实现

最近在使用mybatis,由于是刚刚开始用,用的并不顺手,目前是感觉有2个地方非常的不好用: 1.mybatis调试不方便 由于dao层只有接口,实现只是一个map的xml文件,想加断点都没有地方加,直接导致的后果就是有时候出错了,完全是各种闭眼尝试,抓狂中...倒是可以把调试级别改成debug,会把执行的sql,以及参数都输出到控制台,可是一改成debug,那控制台输出的内容,就实在多到让人发指,甚至都会影响到代码的编写及调试,而且输出日志跟打断点调试根本就不是一个级别的.目前仍旧无法解决改问