gulp配置 - PC
初始化目录结构如下(图片看不清可以拖到桌面或者直接CTRL+鼠标滚轮进行观看)

开发环境示例:

上线环境示例:

gulpfile.js(详解版)
(2018-3-28)添加了scss处理(去除了less处理)
(2018-3-29)添加了实时性处理(在src目录,sass目录下*.css和*.scss放在一起,防止跨域无法请求到)
(2018-3-29)已知错误:生成文件夹dist后index.html无法重命名css和js
(2018-4-12) 修复完毕(最简版)- 点击Github拉取 - 已失效
(2018-7-2) 完成src 和 dist 分类 - 正常使用(项目目录也添加了)Github拉取 -已失效
(2018-7-19) 修改了一些小细节问题,升级了package.json版本,点击Github拉取
(2018-8-10) 上传了丢失的文件夹build.
(2018-8-15) win10 ghost系统也许无法正常使用 - 缺少一些图片处理(建议使用win7或win10正版)
(2018-10-16) npm install 统一改为 yarn install ,否则会报错丢包等
README.md(必看说明文档)
# gulp-demos
#########GULP使用##########
<!-- 依照package.json安装里面的包依赖 -->
1. npm install
<!-- 初始化src目录 -->
2. gulp init
<!-- 初始化src/index.html 和 src/sass/index.scss 文件 -->
3. gulp-file
<!-- 开发 -->
4. gulp
<!-- 打包上线 -->
5. gulp upline ##########开发和生成都是gulp#################
1. 开发目录(src)
2. 打包目录(dist) ###########关于reset-h5##########################
1. 这个是我自制的初始化index.html页面! ############关于build#####################
1. 本来这里是放配置文件,以及打包和生成都要配置的(一切为了快速使用!)
gulpfile.js
var gulp = require('gulp'),
$ = require('gulp-load-plugins')(),
sass = require('gulp-sass'),
open = require('open');
var init = require('./build/gulpfile.init.js');
init();
// 文件路径
var app = {
srcPath: 'src/', //源代码路径
prdPath: 'dist/' //生产环境路径
};
// #######################开发时#########################################
gulp.task('html', function () {
gulp.src(app.srcPath + '/**/*.html')
.pipe($.connect.reload());
});
gulp.task('scss', function () {
return gulp.src(app.srcPath + '/sass/*.scss')
.pipe(sass.sync().on('error', sass.logError))
.pipe(gulp.dest(app.srcPath + 'css'))
.pipe($.connect.reload());
});
gulp.task('css', function () {
gulp.src(app.srcPath + 'css/**/*.css')
.pipe($.autoprefixer({
// 可根据项目需要自行配置需要兼容的版本
browsers: ['last 2 versions']
}))
.pipe(gulp.dest(app.srcPath + 'css'))
.pipe($.connect.reload())
});
gulp.task('js', function () {
gulp.src(app.srcPath + 'js/**/*.js')
.pipe($.concat('index.js'))
.pipe($.uglify())
.pipe($.connect.reload());
});
gulp.task('images', function () {
gulp.src(app.srcPath + 'images/**/*')
.pipe($.imagemin({
optimizationLevel: ,
progressive: true,
interlaced: true
}))
.pipe($.connect.reload());
});
gulp.task('build', ['images', 'js', 'scss', 'css', 'html']);
// ######################################项目上线#################################################
gulp.task('htmlmin', function () {
const options = {
removeComments: true, //清除HTML注释
collapseWhitespace: true, //压缩HTML
collapseBooleanAttributes: true, //省略布尔属性的值 <input checked="true"/> ==> <input />
removeEmptyAttributes: true, //删除所有空格作属性值 <input id="" /> ==> <input />
removeScriptTypeAttributes: true, //删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true, //删除<style>和<link>的type="text/css"
minifyJS: true, //压缩页面JS
minifyCSS: true //压缩页面CSS
};
gulp.src(app.srcPath + '/**/*.html')
.pipe($.changed(app.prdPath))
.pipe($.htmlmin(options))
// 生产目录
.pipe(gulp.dest(app.prdPath))
.pipe($.notify({
message: 'HTML has been packaged!'
}));
});
gulp.task('cssmin', function () {
gulp.src(app.srcPath + 'css/**/*.css')
.pipe($.changed(app.srcPath))
.pipe($.autoprefixer({
// 可根据项目需要自行配置需要兼容的版本
browsers: ['last 2 versions']
}))
.pipe($.cssmin({
//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]
advanced: false,
//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]
compatibility: 'ie8',
//类型:Boolean 默认:false [是否保留换行]
keepBreaks: false
}))
.pipe($.cssnano())
.pipe(gulp.dest(app.prdPath + 'css'))
.pipe($.notify({
message: 'CSS has been packaged!'
}));
});
gulp.task('jsmin', function () {
gulp.src(app.srcPath + 'js/**/*.js')
.pipe($.changed(app.prdPath))
.pipe($.concat('index.js'))
.pipe($.uglify())
.pipe(gulp.dest(app.prdPath + 'js'))
});
gulp.task('imagesmin', function () {
gulp.src(app.srcPath + 'images/**/*')
.pipe($.imagemin({
optimizationLevel: ,
progressive: true,
interlaced: true
}))
.pipe(gulp.dest(app.prdPath+'images'));
});
gulp.task('upline', ['htmlmin', 'jsmin', 'cssmin', 'imagesmin']);
// ######################################项目结束#################################################
gulp.task('serve', ['build'], function () {
$.connect.server({
root: [app.srcPath],
livereload: true,
port:
});
open('http://localhost:3000');
gulp.watch(app.srcPath + '**/*.html', ['html']);
gulp.watch(app.srcPath + 'data/**/*.json', ['json']);
gulp.watch(app.srcPath + 'sass/**/*.scss', ['scss']);
gulp.watch(app.srcPath + 'css/**/*.css', ['css']);
gulp.watch(app.srcPath + 'js/**/*.js', ['js']);
gulp.watch(app.srcPath + 'images/**/*', ['images']);
});
gulp.task('default', ['serve']);
package.json
{
"name": "gulp-demos",
"version": "1.0.0",
"description": "",
"main": "index.js",
"dependencies": {},
"devDependencies": {
"browser-sync": "^2.18.8",
"del": "^3.0.0",
"gulp": "^3.9.1",
"gulp-changed": "^3.2.0",
"gulp-clean": "^0.4.0",
"gulp-concat": "^2.6.1",
"gulp-connect": "^5.5.0",
"gulp-cssmin": "^0.2.0",
"gulp-imagemin": "^4.1.0",
"gulp-less": "^4.0.0",
"gulp-load-plugins": "^1.5.0",
"gulp-sass": "^3.2.1",
"gulp-uglify": "^3.0.0",
"gulp-rename": "^1.2.2",
"gulp-cssnano": "^2.1.2",
"htmlmin": "^0.0.7",
"gulp-autoprefixer": "^5.0.0",
"gulp-notify": "^3.2.0",
"gulp-htmlmin": "^4.0.0",
"gulp-rev": "^8.1.1",
"open": "0.0.5"
},
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC"
}
gulp-file.bat
@echo off >>src/sass/index.scss
@echo off >>src/index.html
type reset-h5.html>>src/index.html
reset-h5.html
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge,chrome=1">
<link rel="stylesheet" href="./css/index.css">
<title>Document</title>
</head> <body>
6666
</body> </html>
build/gulpfile.config.js
var SRC_DIR = './src/'; // 源文件目录
var DIST_DIR = './dist/'; // 文件处理后存放的目录
var DIST_FILES = DIST_DIR + '**'; // 目标路径下的所有文件 var Config = {
src: SRC_DIR,
dist: DIST_DIR,
dist_files: DIST_FILES,
html: {
dir: SRC_DIR,
src: SRC_DIR + '*.html',
dist: DIST_DIR
},
json: {
dir: SRC_DIR,
src: SRC_DIR + 'data/**/*.json',
dist: DIST_DIR + 'json'
},
assets: {
dir: SRC_DIR + 'assets',
src: SRC_DIR + 'assets/**/*', // assets目录:./src/assets
dist: DIST_DIR + 'assets' // assets文件build后存放的目录:./dist/assets
},
css: {
dir: SRC_DIR + 'css',
src: SRC_DIR + 'css/**/*.css', // CSS目录:./src/css/
dist: DIST_DIR + 'css' // CSS文件build后存放的目录:./dist/css
},
sass: {
dir: SRC_DIR + 'sass',
src: SRC_DIR + 'sass/**/*.scss', // SASS目录:./src/sass/
dist: DIST_DIR + 'css' // SASS文件生成CSS后存放的目录:./dist/css
},
js: {
dir: SRC_DIR + 'js',
src: SRC_DIR + 'js/**/*.js', // JS目录:./src/js/
dist: DIST_DIR + 'js', // JS文件build后存放的目录:./dist/js
build_name: 'build.js' // 合并后的js的文件名
},
img: {
dir: SRC_DIR + 'images',
src: SRC_DIR + 'images/**/*', // images目录:./src/images/
dist: DIST_DIR + 'images' // images文件build后存放的目录:./dist/images
}
}; module.exports = Config;
build/gulpfile.init.js
var gulp = require('gulp');
var mkdirp = require('mkdirp');
var Config = require('./gulpfile.config.js');
//======= gulp init 初始化项目结构 ===============
function init() {
/**
* 初始化项目结构
*/
gulp.task('init', function() {
var dirs = [Config.html.dir, Config.assets.dir, Config.css.dir, Config.sass.dir, Config.js.dir, Config.img.dir];
dirs.forEach(dir => {
mkdirp.sync(dir);
});
});
}
module.exports = init;
gulp配置 - PC的更多相关文章
- gulp配置
/* gulp配置 */ /* gulp配置 */ var gulp = require('gulp'), concat = require('gulp-concat'), rename = requ ...
- Scss开发临时学习过程||webpack、npm、gulp配置
SCSS语法: 假设变量申明带有!default,那么如果在此申明之前没有这个变量的申明,则用这个值,反之如果之前有申明,则用申明的值. ‘...’传递多个参数: @mixin box-shadow( ...
- gulp配置,实例演示
项目完成后的目录 我们所需要的插件为:gulp-minify-css gulp-concat gulp-uglify gulp-rename del 如下图所示,完成后的项目目录结构: 附加,获取pa ...
- gulp配置文件备份
/** * Created by leyi on 2016/8/25 0025. */ /*********************package.json依赖模块****************** ...
- gulp 配置前端项目打包
项目发布时,需要对项目js文件进行压缩,混淆,连接等操作以减小项目http请求,加快访问. gulpjs.com中有很多插件可以用来配置打包部署. 需要用的常用插件有: gulp-jsmin 压缩j ...
- gulp 配置自动化前端开发
有的人说,grunt已经廉颇老矣,尚能饭否.gulp已经成为了未来的趋势,或许将撼动grunt的地位. 那么就得看看gulp到底优势在哪里,在我最近的使用中发现,我的到了一个结论:“grunt廉颇老矣 ...
- gulp配置版本号 教程之gulp-rev-append
简介: 使用gulp-rev-append给页面的引用添加版本号,清除页面引用缓存. 1.安装nodejs/全局安装gulp/项目安装gulp/创建package.json和gulpfile.js文件 ...
- Express+Less+Gulp配置高效率开发环境
版权声明:本文由金朝麟原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/627049001486519548 来源:腾云阁 h ...
- 流行得前端构建工具比较,以及gulp配置
前端现在三足鼎立的构建工具(不算比较老的ant,yeoman),非fis,grunt,gulp莫属了. fis用起来最简单,我打算自己得项目中使用一下fis. 先说一下gulp安装吧. 第一步:安装n ...
随机推荐
- Linux 特殊权限位简介
suid.guid suid 针对二进制命令或者程序,让其拥有root或者属主权限执行 一.setsuid : chmod 4755 二进制命令或者程序 chmod u+s 二进制命令或者程序 示 ...
- python爬虫基础04-网页解析库xpath
更简单高效的HTML数据提取-Xpath 本文地址:https://www.jianshu.com/p/90e4b83575e2 XPath 是一门在 XML 文档中查找信息的语言.XPath 用于在 ...
- python--类的约束, 异常处理, MD5, 日志处理
一 . 类的约束 1. 写一个父类,父类中的某个方法要抛出一个异常 NotImplementedError class Base: # 对子类进行了约束. 必须重写该方法 # 以后上班了. 拿到公司代 ...
- 我的Python分析成长之路2
2018-12-29 一.python数据类型: 1.数字 int(整形) float(浮点型) complex(复数型) 2.布尔值(bool) 真或假 True or False 3.字符 ...
- The North American Invitational Programming Contest 2018 H. Recovery
Consider an n \times mn×m matrix of ones and zeros. For example, this 4 \times 44×4: \displaystyle \ ...
- PHP 微信分享(及二次分享)
js部分: <script src="http://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script> &l ...
- linux open()文件操作
python程序中经常用到的读文件: f = open("___", 'r') for line in f:#这里每次读取文件的一行,line为字符串,串尾包括了'\n'!!! ...
- 九度oj 题目1108:堆栈的使用
题目描述: 堆栈是一种基本的数据结构.堆栈具有两种基本操作方式,push 和 pop.Push一个值会将其压入栈顶,而 pop 则会将栈顶的值弹出.现在我们就来验证一下堆栈的使用. 输入: 对于每组测 ...
- shell的case-esac
case ... esac 与其他语言中的 switch ... case 语句类似,是一种多分枝选择结构. case 语句匹配一个值或一个模式,如果匹配成功,执行相匹配的命令.case语句格式如下: ...
- 【2018.2.8-】网络流学习笔记(含ISAP!)
网络流的基础内容就不详细发了,网上到处都是,可自学. 总版点这里 ps:以下有些链接是hihocoder的题目(题面有详细讲解),请确保先登录hihocoder,再点击进入相应题目网页. 最大流 基础 ...