欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用gulp構建前端自動化的方法示例

 更新時間:2018年12月25日 10:51:07   作者:_CL2  
這篇文章主要介紹了使用gulp構建前端自動化的方法示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

gulp是一個自動化構建工具,開發(fā)者可以用它來自動執(zhí)行一些常見的任務。這里以我之前做的一個demo為例,簡要介紹如何使用gulp實現前端工程自動化。

項目結構

其中src目錄下表示的是項目的源代碼,可以看到其中有l(wèi)ess、js、html等,而dist目錄則是保存的是gulp編譯后生成的代碼,相當于生產環(huán)境。最后也最重要的是gulpfile.js,這個文件用于設置gulp相關的配置,類似于webpack中的webpack.config.js。

安裝

這里使用的gulp為v3.9.1,語法和最新的v4.x有所出入,想學習最新的gulp語法,可以參考gulp.js - The streaming build system

3.9.1 安裝如下:

npm install --save-dev gulp

語法

  • gulp.task()用于定義一個gulp任務,在命令行中可以使用gulp [任務名]開啟該任務。
  • gulp.src()會返回符合匹配的文件流,可以被pipe()到其他插件中。
  • gulp.dest():輸出所有數據。
  • gulp.watch()用于監(jiān)測文件的變動。

實踐

在這個項目中,有一些常見的需求,這里使用gulp來實現自動化:

  • less轉css
  • css壓縮合并
  • js壓縮合并
  • 圖片壓縮

在gulpfile.js中首先需要導入gulp和一些常用的插件,本次demo使用到的插件如下:

var gulp = require('gulp'),
  less = require('gulp-less'),          //less 轉 css
  csso = require('gulp-csso'),          //css壓縮
  concat = require('gulp-concat'),        //合并文件
  uglify = require('gulp-uglify'),        //js 壓縮
  jshint = require('gulp-jshint'),        //js 檢查
  clean = require('gulp-clean'),         //清除文件
  imagemin = require('gulp-imagemin'),      //圖片壓縮
  rev = require('gulp-rev'),           //添加版本號
  revReplace = require('gulp-rev-replace'),   //版本號替換
  useref = require('gulp-useref'),        //解析html資源定位
  gulpif = require('gulp-if'),          //if語句
  connect = require('gulp-connect');       //創(chuàng)建web服務器

圖片壓縮

獲取到src下所有以.jpg或.png結尾的圖片,將其壓縮后輸出到dist目錄下。

gulp.task('dist:img', () => {
  gulp.src(['./src/**/*.jpg', './src/**/*.png'])
  .pipe(imagemin())
  .pipe(gulp.dest('dist/'))
})

less壓縮合并為css

先清除已存在的css,然后將src下以.less結尾的文件通過less()轉為css文件,再通過csso()以及concat()實現對css的壓縮合并。

gulp.task('dist:css', () => {
  gulp.src('dist/css/*.css').pipe(clean());
  return gulp.src('./src/less/*.less')
  .pipe(less())
  .pipe(csso())
  .pipe(concat('public.css'))
  .pipe(gulp.dest('dist/css/'));
});

js壓縮合并

js壓縮合并的過程大同小異,增加了一個jshint()代碼審查的過程,它會將不符合規(guī)范的錯誤代碼輸出到控制臺。

gulp.task('dist:js', () => {
  gulp.src('dist/js/*.js').pipe(clean());
  return gulp.src('./src/js/*.js')
  .pipe(jshint())
  .pipe(jshint.reporter('default'))
  .pipe(uglify())
  .pipe(concat('public.js'))
  .pipe(gulp.dest('dist/js/'))
});

less=>css

在開發(fā)過程中,因為html不能直接引入.less文件,因此還需要生成開發(fā)環(huán)境的.css。

gulp.task('src:css', () => {
  gulp.src('src/css/*.css').pipe(clean());
  return gulp.src('./src/less/*.less')
  .pipe(less())
  .pipe(gulp.dest('src/css/'));
});

添加版本號

為了防止瀏覽器對文件進行緩存,需要對文件添加版本號,保證每次獲取到的都是最新的代碼。

gulp.task('revision', ['dist:css', 'dist:js'], () => {
  return gulp.src(["dist/css/*.css", "dist/js/*.js"])
  .pipe(rev())
  .pipe(gulpif('*.css', gulp.dest('dist/css'), gulp.dest('dist/js')))
  .pipe(rev.manifest())
  .pipe(gulp.dest('dist'))
})

gulp.task('build', ['dist:img'], () => {
  var manifest = gulp.src('dist/rev-manifest.json');
  return gulp.src('src/index.html')
  .pipe(revReplace({
    manifest: manifest
  }))
  .pipe(useref())
  .pipe(gulp.dest('dist/'))
})

在revision中,首先通過rev()對dist目錄下的.css/.js生成一個文件名帶版本號的文件,例如本例中public.css生成public-5c001c53f6.css,然后分別輸出到不同的目錄下,最后生成一個rev-manifest.json文件,存儲了原文件和帶版本號文件之間的映射關系,如下:

{
 "public.css": "public-5c001c53f6.css",
 "public.js": "public-93c275a836.js"
}

在build中,先獲取到rev-manifest.json中的對象,然后利用revReplace()來替換版本號,再使用useref()來進行資源的解析定位,最后輸出即可。

以引入js文件為例,源html文件中對文件的引入則要改寫為以下形式,即以注釋的形式寫入構建后生成的文件路徑,如下:

<!-- build:js ./js/public.js -->
<script src="./js/jquery-1.12.4.min.js"></script>
<script src="./js/myAlbum.js"></script>
<!-- endbuild -->

最后生成的html為:

<script src="./js/public-93c275a836.js"></script>

具體的語法規(guī)則可以參見gulp-useref。

創(chuàng)建本地服務器并實現自動刷新

使用connet.server()來創(chuàng)建一個本地服務器,利用gulp.watch()來對src下的文件進行監(jiān)測,如果發(fā)生變化,則執(zhí)行編譯less為css和刷新頁面的任務。

gulp.task('connect', () => {
  connect.server({
    root: 'src',
    livereload: true,
    port: 8888
  })
})

gulp.task('reload', () => {
  gulp.src('src/*.html')
  .pipe(connect.reload())
})

gulp.task('watch', () => {
  gulp.watch('src/**/*', ['src:css', 'reload'])
})

完整的代碼可以參見github

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 原生JavaScript實現Ajax的方法

    原生JavaScript實現Ajax的方法

    這篇文章主要介紹了原生JavaScript實現Ajax的幾種方法,感興趣的小伙伴們可以參考一下
    2016-04-04
  • JS勻速運動演示示例代碼

    JS勻速運動演示示例代碼

    勻速運動的效果想必大家都有見到過吧,在本文為大家介紹下使用JS是如何實現的,感興趣的朋友不要錯過
    2013-11-11
  • JavaScript Ajax實現異步通信

    JavaScript Ajax實現異步通信

    這篇文章主要為大家詳細介紹了JavaScript Ajax實現異步通信的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • 微信小程序以ssm做后臺開發(fā)的實現示例

    微信小程序以ssm做后臺開發(fā)的實現示例

    這篇文章主要介紹了微信小程序以ssm做后臺開發(fā)的實現示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • JS利用正則表達式實現簡單的密碼強弱判斷實例

    JS利用正則表達式實現簡單的密碼強弱判斷實例

    這篇文章主要給大家介紹了關于JS利用正則表達式實現簡單的密碼強弱判斷的相關資料,實現后的效果非常簡單,但也挺實用的,文中給出了詳細的示例代碼供大家參考學習,需要的朋友們下面來一起看看吧。
    2017-06-06
  • Javascript條件判斷使用小技巧總結

    Javascript條件判斷使用小技巧總結

    我們已經知道,null?沒有任何的屬性值,并且無法獲取其實體(existence)值。所以?null.property?返回的是錯誤(error)而不是?undefined?。
    2008-09-09
  • js實現用戶離開頁面前提示是否離開此頁面的方法(包括瀏覽器按鈕事件)

    js實現用戶離開頁面前提示是否離開此頁面的方法(包括瀏覽器按鈕事件)

    這篇文章主要介紹了js實現用戶離開頁面前提示是否離開此頁面的方法,較為詳細的分析了javascript針對瀏覽器事件的操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • js實現限定區(qū)域范圍拖拉拽效果

    js實現限定區(qū)域范圍拖拉拽效果

    這篇文章主要為大家詳細介紹了js實現限定區(qū)域范圍拖拉拽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • js與css實現彈出層覆蓋整個頁面的方法

    js與css實現彈出層覆蓋整個頁面的方法

    這篇文章主要介紹了js與css實現彈出層覆蓋整個頁面的方法,分別以實例形式展示了彈出層覆蓋整個頁面的css樣式與js控制的實現技巧,非常具有實用價值,需要的朋友可以參考下
    2014-12-12
  • JavaScript基于對象方法實現數組去重及排序操作示例

    JavaScript基于對象方法實現數組去重及排序操作示例

    這篇文章主要介紹了JavaScript基于對象方法實現數組去重及排序操作,涉及javascript基于對象方法的數組遍歷、比較、去重、排序等相關操作技巧,需要的朋友可以參考下
    2018-07-07

最新評論