前端自动化部署之gulp

1.首先需要安装node+npm(这里不再叙述,网上教程一大堆)

2.gulp全局安装:npm install -g gulp

3.cd进入到你的项目目录,这里使用demo文件夹为我的示例项目

4.在demo项目中新建dist和src两个文件夹,再在src文件夹下新建images,sass,js三个文件夹和index.html文件

5.命令行cd进入到项目根目录,在项目中安装gulp模块,npm install gulp

6.安装gulp相关需要模块

npm install gulp-util gulp-imagemin gulp-ruby-sass gulp-minify-css gulp-jshint gulp-uglify gulp-rename gulp-concat gulp-clean gulp-livereload tiny-lr

关于各模块介绍及连接(也可通过gulp plugins,寻找相应功能的gulp模块):

gulp-imagemin: 压缩图片
gulp-ruby-sass: 支持sass
gulp-minify-css: 压缩css
gulp-jshint: 检查js
gulp-uglify: 压缩js
gulp-concat: 合并文件
gulp-rename: 重命名文件
gulp-htmlmin: 压缩html
gulp-clean: 清空文件夹
gulp-livereload: 服务器控制客户端同步刷新(需配合chrome插件LiveReloadtiny-lr

6.安装后在项目根目录下新建gulpfile.js文件,插入以下代码:

/**
 * 组件安装
 * npm install gulp-util gulp-imagemin gulp-ruby-sass gulp-minify-css gulp-jshint gulp-uglify gulp-rename gulp-concat gulp-clean gulp-livereload tiny-lr --save-dev
 */

// 引入 gulp及组件
var gulp    = require(‘gulp‘),                 //基础库
    imagemin = require(‘gulp-imagemin‘),       //图片压缩
    sass = require(‘gulp-ruby-sass‘),          //sass
    minifycss = require(‘gulp-minify-css‘),    //css压缩
    jshint = require(‘gulp-jshint‘),           //js检查
    uglify  = require(‘gulp-uglify‘),          //js压缩
    rename = require(‘gulp-rename‘),           //重命名
    concat  = require(‘gulp-concat‘),          //合并文件
    clean = require(‘gulp-clean‘),             //清空文件夹
    tinylr = require(‘tiny-lr‘),               //livereload
    server = tinylr(),
    port = 35729,
    livereload = require(‘gulp-livereload‘);   //livereload

// HTML处理
gulp.task(‘html‘, function() {
    var htmlSrc = ‘./src/*.html‘,
        htmlDst = ‘./dist/‘;

    gulp.src(htmlSrc)
        .pipe(livereload(server))
        .pipe(gulp.dest(htmlDst))
});

// 样式处理
gulp.task(‘css‘, function () {
    var cssSrc = ‘./src/scss/*.scss‘,
        cssDst = ‘./dist/css‘;

    gulp.src(cssSrc)
        .pipe(sass({ style: ‘expanded‘}))
        .pipe(gulp.dest(cssDst))
        .pipe(rename({ suffix: ‘.min‘ }))
        .pipe(minifycss())
        .pipe(livereload(server))
        .pipe(gulp.dest(cssDst));
});

// 图片处理
gulp.task(‘images‘, function(){
    var imgSrc = ‘./src/images/**/*‘,
        imgDst = ‘./dist/images‘;
    gulp.src(imgSrc)
        .pipe(imagemin())
        .pipe(livereload(server))
        .pipe(gulp.dest(imgDst));
})

// js处理
gulp.task(‘js‘, function () {
    var jsSrc = ‘./src/js/*.js‘,
        jsDst =‘./dist/js‘;

    gulp.src(jsSrc)
        .pipe(jshint(‘.jshintrc‘))
        .pipe(jshint.reporter(‘default‘))
        .pipe(concat(‘main.js‘))
        .pipe(gulp.dest(jsDst))
        .pipe(rename({ suffix: ‘.min‘ }))
        .pipe(uglify())
        .pipe(livereload(server))
        .pipe(gulp.dest(jsDst));
});

// 清空图片、样式、js
gulp.task(‘clean‘, function() {
    gulp.src([‘./dist/css‘, ‘./dist/js‘, ‘./dist/images‘], {read: false})
        .pipe(clean());
});

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

// 监听任务 运行语句 gulp watch
gulp.task(‘watch‘,function(){
    livereload.listen();
        // 监听html
        gulp.watch(‘./src/*.html‘, function(event){
            gulp.run(‘html‘);
        })

        // 监听css
        gulp.watch(‘./src/scss/*.scss‘, function(){
            gulp.run(‘css‘);
        });

        // 监听images
        gulp.watch(‘./src/images/**/*‘, function(){
            gulp.run(‘images‘);
        });

        // 监听js
        gulp.watch(‘./src/js/*.js‘, function(){
            gulp.run(‘js‘);
        });
});

7.安装npm的http-server模块,快速建立http服务:npm install -g http-server

8.安装浏览器LiveReload插件,目前我知道的关于Safari、Firefox、Chrome都有此插件,网上搜下吧,我就不提供了

9.运行http-server,在重新打开一个命令行窗口启动gulp:

  第一个cmd窗口:

http-server

  第二个cmd窗口:

gulp watch

这时,打开安装过livereload插件的浏览器输入localhost:8080就可以了,并点击livereload插件图标激活链接即可(http-server默认为8080端口),这时更改src文件夹下的文件(可以拿html文件更改试下【最好结构完整,不要连html,head,body都不写】)时,保存后,就会看到浏览器自动刷新了。

关于这个插件网上大部分人介绍的都是chrome的,但我更建议用Firefox的,因为Firefox的体验更好些,因为在chrome中时保存后又是页面没变化,需要多按几下ctrl+s才会刷新页面,但在firefox下我就没有发现这个问题。

10.到此,初步的尝试gulp前端自动化开发就完事了,但继续探索gulp的步伐才刚刚开始,如果有更好的gulp教程,希望能介绍给我和大家知道,先在这里谢过了,好了,我也要休息下,看看影视了,就到这里吧。

时间: 2024-08-08 17:49:06

前端自动化部署之gulp的相关文章

web 环境搭建00前端自动化构建工具(gulp)

web 环境搭建----前端自动化构建工具(gulp): 1----先下载安装node.js 2----然后在node.js命令行安装:npm install gulp -g (全局下载安装gulp插件) 3----然后进入到项目文件夹(命令cd 文件夹名),在项目文件夹中安装依赖文件:npm install gulp --save-dev (根据依赖文件下载gulp插件) 4----在项目文件夹目录下初始化:npm init (初始化文件) {初始化文件后项目中会出现packgae.json文

前端自动化之神器 — Gulp

Nodejs不仅把Javascript带到了服务端,也在前端掀起了自动化的浪潮,推动了前端工作的历史性巨变,今天和大家一起学习前端自动化的神器---Gulp; 说起自动化,自然少不了Grunt,这位前辈目前社区完善,拥有几千个现成插件,install下来参考文档即可配置使用(参见:前端自动化之利剑——Grunt):而Gulp的出现,希望取其精华并取代Grunt,成为最流行的Javascript构建工具,Gulp采用代码优于配置的策略,让简单的事继续简单,让复杂的事变得可管理: 与Grunt的不同

前端自动化构建工具——gulp

gulp是基于流的前端自动化构建工具. 一.环境配置 gulp是基于nodejs的,所以没有 nodejs 环境的要先去安装好 然后给系统配上gulp环境 npm install -g gulp 再到某一工程目录下 跟grunt一般,也是需要package.json包依赖文件和一个入口文件 gulpfile.js(其他名字识别不了) 然后就类似的先装上gulp npm install gulp --save-dev 最基本的使用方式是这样:(使用jshint插件校验js代码) var jshin

前端自动化构建之gulp

前言 之前学完html的基础后就去学js框架了,每次都是用脚手架搭好的文件,在无形中体验了一波前端自动化带来的方便.然后前一段时间才开始学习前端自动化. 基本介绍 gulp说得简单一点就是一个自动化把前端的各种工具以流的方式一步一步的按照设置的规定加载的一个管理工具 装载 首先全局安装gulp npm install --global gulp 然后你需要在根目录下创建一个名为gulpfile.js的文件 这个文件是gulp命令需要加载的文件,通过这个文件来处理预设的构建 使用 首先你可以在你的

前端自动化部署的深度实践

年前我也在自动化部署这方面下了点功夫,将自己的学习所得在自动化部署的一小步,前端搬砖的一大步这篇博客中做了分享.感谢两位网友@_shanks和@TomCzHen的意见,让我有了继续优化部署流程的动力.本文主要是在自动化部署流程中,对版本管理和流程合理性等方面做了一些改进,配合规范的工作流,使用体验更佳! 更新日志自动生成 之前我都是手动修改CHANGELOG.md,用来记录更新日志,感觉操作起来有点心累,也不是很规范.好在已有前人种树,于是我就考虑利用conventional-changelog

前端自动化构建工具gulp记录

什么是gulp 答:Gulp 是一款基于任务的设计模式的自动化工具,通过插件的配合解决全套前端解决方案,如静态页面压缩.图片压缩.JS合并.SASS同步编译并压缩CSS.服务器控制客户端同步刷新.. 为什么要用gulp? 1.js和css属于静态文件,很多时候浏览器存在缓存机制,为了避免缓存带来的误会,可以利用构建工具,给每一个静态文件添加一个版本号,这样浏览器就会认为是新的文件,就不存在缓存机制. 2.性能优化:文件合并,减少http请求:文件压缩,减少文件体积,加快下载速度: 3.效率提升:

前端自动化构建工具gulp使用

1. 全局安装 gulp: $ npm install --global gulp 2. 作为项目的开发依赖(devDependencies)安装: $ npm install --save-dev gulp 3. 在项目根目录下创建一个名为 package.json 的文件: 附上本人项目基本配置 { "devDependencies": { "concat": "0.0.1-security", "gulp": "

前端自动化构建工具gulp(二)

创建一个真实的例子: 创建一个项目,结构如图 gulp的使用方法通常是这样的 gulp.task('task-name', function () { return gulp.src('source-files') // source-files是任务的入口文件路径 .pipe(aGulpPlugin()) // 调用插件 .pipe(gulp.dest('destination')) //destination执行任务输出文件路径 }) 我们将使用gulp-sass插件来编译sass: 1.安

Ubuntu系统Jenkins+nodejs+webPack前端自动化部署

一.环境准备(java,maven,nodejs,webpack)环境部分略过总之缺什么依赖就apt什么[[email protected] ~]# tar zxvf jdk-8u91-linux-x64.tar.gz -C /opt/ [[email protected] ~]# tar xvf apache-maven-3.5.0-bin.tar.gz -C /opt/ [[email protected] ~]#wget http://cdn.npm.taobao.org/dist/nod