gulp布局构建小结
一、工具选择
CSS预处理语言LESS
构建工具gulp(基于node环境)
gulp插件:
gulp-connect——主要是用来运行一个webserver
npm install --save-dev gulp-connect
插件介绍:https://www.npmjs.com/package/gulp-connect
gulp.spritesmith——雪碧图
npm install gulp.spritesmith --save-dev
插件介绍:https://www.npmjs.com/package/gulp.spritesmith
gulp-less——less转CSS
npm install gulp-less --save-dev
插件介绍:https://www.npmjs.com/package/gulp-less
PS切图工具:
cutandslice——这是一款快速裁切透明图标的工具,配合spritesmith使用,可以很快的生成雪碧图片,整合多张小图,减少有服务器请求。
工具网址:http://www.cutandslice.me/#en
教程网址:http://www.zcool.com.cn/article/ZNDYzODA=.html
二、目录设定
|- \ [根目录]
|--project
|--- dist [临时生成点,可随时删除]
|--- images [图片文件夹]
|--- icon [内存放common、member_center两个文件图标]
|--- js [JS文件]
|--- less [less样式]
|--- member_center [用户后台样式]
|--- part [公用样式]
|--- ./ [PC前台样式]
|--- member_center [用户后台html文件]
|--- ./ [PC html文件]
|-- node_modules [node模块]
|-- PSD [PSD文件存放点]
|-- gulpfile.js [gulp 配置文件]
|-- package.json [node模块包文件]
三、gulpfile规则编写
- 加载模块
var gulp = require('gulp'),
connect = require('gulp-connect'),
del = require('del'),
minifyCSS = require('gulp-minify-css'),
spritesmith = require('gulp.spritesmith'),
less = require('gulp-less');
- 创建任务,将开发模式下的文件放置到dist目录
task[dist_html]:用于处理html文件gulp.task('dist_html',function(){
return gulp.src('./project/**/*.html')
.pipe(gulp.dest('./project/dist'))
})task[dist_js]:用于处理JS文件
gulp.task('dist_js',function(){
return gulp.src('project/js/**/*.js')
.pipe(gulp.dest('project/dist/js'));
})task[dist_less]:用于处理less文件,将其转为css
gulp.task('dist_Less', function () {
return gulp.src('project/less/*.less')
.pipe(less())
.pipe(gulp.dest('project/dist/css/front'));
})task[dist_img]:移动图片到dist目录
gulp.task('dist_img',['dist_icon'],function(){
return gulp.src(['./project/images/**/*.{png,jpeg,gif,jpg}'])
.pipe(gulp.dest('./project/dist/images/'))
})task[sprite_common]:整合image/icon/common下的目录到icon.png
gulp.task('sprite_common', function () { return gulp.src('project/images/front/icon/common/*.png')//需要合并的图片地址
.pipe(spritesmith({
imgName: 'icon.png',//保存合并后图片的地址
cssName: 'sprite.less',//保存合并后对于css样式的地址
padding:5,//合并时两个图片的间距
algorithm: 'top-down',//注释1
cssTemplate: function (data) {
var arr=[];
data.sprites.forEach(function (sprite) {
arr.push(".icon."+sprite.name+
"{" +
"background-image: url('/images/front/"+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('project/less/part'));
});task[del_old_icon]:删除旧的icon.png
gulp.task('del_old_icon',function(){
del(['./project/images/front/icon.png']);
})task[dist_icon]:移动新的icon.png到/image下
注:dist_icon执行前会先执行del_old_icongulp.task('dist_icon',['del_old_icon'],function(){
return gulp.src(['./project/less/part/icon.png')
.pipe(gulp.dest('./project/images/front/'));
})task[del_dist]:删除dist目录
gulp.task('del_dist',function(){
del('./project/dist/');
})
- 整合任务以便调用执行
总的任务整合为两部分,一部分为雪碧图整合,另一部分为dist目录生成。gulp.task('default',['dist_Less','dist_html','dist_js','dist_img']);
gulp.task('sprite',['sprite_common']);
gulp布局构建小结的更多相关文章
- 关于node.js和npm,cnpm的安装记录以及gulp自动构建工具的使用
关于node.js和npm,cnpm的安装记录以及gulp自动构建工具的使用 工作环境:window下 在一切的最开始,安装node.js (中文站,更新比较慢http://nodejs.cn/) ...
- gulp进阶构建项目由浅入深
gulp进阶构建项目由浅入深 阅读目录 gulp基本安装和使用 gulp API介绍 Gulp.src(globs[,options]) gulp.dest(path[,options]) gulp. ...
- 基于Gulp + Browserify构建es6环境下的自动化前端项目
随着React.Angular2.Redux等前沿的前端框架越来越流行,使用webpack.gulp等工具构建前端自动化项目也随之变得越来越重要.鉴于目前业界普遍更流行使用webpack来构建es6( ...
- gulp自动化构建工具的使用
gulp自动化构建工具: 把前端开发常见的处理(“搬砖”)程序,通过一个工具模块管理起来,只需配置一次,达到自动处理目的,简化开发,提高效率!! 安装: 1.全局安装(全局安装一个gulp命令) A. ...
- gulp 前端构建工具入门
gulp 前端构建工具入门 标签(空格分隔): gulp 1. 安装gulp npm i -g gulp 2. 创建gulp项目 2.1 Hello world 使用npm init初始化项目文件夹. ...
- gulp 自动化构建html项目--自动刷新
使用gulp自动化构建项目是前端学习的重要部分,gulp依赖于node.js.首选电脑要配置node和npm. 查看node版本号 node --version 查看npm 版本 npm --vers ...
- 使用ConstraintLayout(约束布局)构建响应式UI
使用ConstraintLayout(约束布局)构建响应式UI 转 https://www.300168.com/yidong/show-2740.html 核心提示:ConstraintLa ...
- gulp 前端构建工具使用
gulp 前端构建工具使用 1.新建一个web h5项目 2.准备好gulpfile.js文件 (1)下载链接:https://pan.baidu.com/s/116J-BaYOMRzeJW3i_J ...
- 应用gulp工具构建个自动算rem布局的小例子
因为最近可能需要做移动端rem布局,因为rem布局需要将px转化成rem,如果次都需要拿计算器算就太low了,所以就想到用less和gulp. 因为也是初学gulp,站点的文件结构还没想到太好,也只是 ...
随机推荐
- Linux删除文件名中包含“-”的文件
背景: 练习用shell的一些特殊符号,输出了一个 cat test.txt > -n,结果创建了一个叫做“-n”的文件 问题: 使用rm -f -n删除不了“-n"文件 解决 ...
- AtomEye的使用
网易博客粗略地在转载的基础上对AtomEye补充了概述: AtomEye: Atomistic configuration viewer developed by J. Li. This progra ...
- MYSQL错误:You can't specify target table for update in FROM clause
这句话意思是:不能先select再更新(修改)同一个表. 可以再外嵌套多一层,这个问题只有mysql有,mssql和oracle都没有. # 出错delete from Person where Id ...
- Django的mode的分组查询和聚合查询和F查询和Q查询
1.聚合查询 # 聚合函数aggregate,求指定字段的最大值,最小值,平均值,和的值,方法如下 from django.db.models import Avg from django.db.mo ...
- [leetcode]367. Valid Perfect Square验证完全平方数
Given a positive integer num, write a function which returns True if num is a perfect square else Fa ...
- js-addEventListener()第三个参数useCapture
概述: 第3个参数叫做useCapture,是一個boolean值,就是true or false .如果送出true的話就是瀏覽器會使用Capture方式,false的話是Bubbling,只有在特 ...
- Message: u'The given selector btn dropdown-toggle btn-info is either invalid or does not result in a WebElement
html代码: <html> <head> <meta http-equiv="content-type" content="text/ht ...
- c语言使用指针实现模拟java/c# string.concat字符串串联方法
#include <stdio.h> void _strcat(char *, const char *); int main(void) { char source[] ="V ...
- BZOJ1222 [HNOI2001]产品加工 - 动态规划- 背包
题解 怎么看都不像是个背包,直到我看了题解→_→, 第一次碰到这么奇怪的背包= = 定一个滚动数组$F_i$, $i$表示机器$a$用了$i$的时间, $F_i$表示机器$b$用了$F_i$的时间, ...
- python不用声明数据类型
不用声明变量一样,Python不用去声明函数的返回类型,是由于其“若类型”的语言特性决定的. 在其他语言中,例如C/C++语言中在存储一个数据之前,都需要在内存中给这个数据开辟一个固定的内存空间,并给 ...