一、工具选择
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_icon

    gulp.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布局构建小结的更多相关文章

  1. 关于node.js和npm,cnpm的安装记录以及gulp自动构建工具的使用

    关于node.js和npm,cnpm的安装记录以及gulp自动构建工具的使用   工作环境:window下 在一切的最开始,安装node.js (中文站,更新比较慢http://nodejs.cn/) ...

  2. gulp进阶构建项目由浅入深

    gulp进阶构建项目由浅入深 阅读目录 gulp基本安装和使用 gulp API介绍 Gulp.src(globs[,options]) gulp.dest(path[,options]) gulp. ...

  3. 基于Gulp + Browserify构建es6环境下的自动化前端项目

    随着React.Angular2.Redux等前沿的前端框架越来越流行,使用webpack.gulp等工具构建前端自动化项目也随之变得越来越重要.鉴于目前业界普遍更流行使用webpack来构建es6( ...

  4. gulp自动化构建工具的使用

    gulp自动化构建工具: 把前端开发常见的处理(“搬砖”)程序,通过一个工具模块管理起来,只需配置一次,达到自动处理目的,简化开发,提高效率!! 安装: 1.全局安装(全局安装一个gulp命令) A. ...

  5. gulp 前端构建工具入门

    gulp 前端构建工具入门 标签(空格分隔): gulp 1. 安装gulp npm i -g gulp 2. 创建gulp项目 2.1 Hello world 使用npm init初始化项目文件夹. ...

  6. gulp 自动化构建html项目--自动刷新

    使用gulp自动化构建项目是前端学习的重要部分,gulp依赖于node.js.首选电脑要配置node和npm. 查看node版本号 node --version 查看npm 版本 npm --vers ...

  7. 使用ConstraintLayout(约束布局)构建响应式UI

    使用ConstraintLayout(约束布局)构建响应式UI 转 https://www.300168.com/yidong/show-2740.html     核心提示:ConstraintLa ...

  8. gulp 前端构建工具使用

    gulp 前端构建工具使用 1.新建一个web  h5项目 2.准备好gulpfile.js文件 (1)下载链接:https://pan.baidu.com/s/116J-BaYOMRzeJW3i_J ...

  9. 应用gulp工具构建个自动算rem布局的小例子

    因为最近可能需要做移动端rem布局,因为rem布局需要将px转化成rem,如果次都需要拿计算器算就太low了,所以就想到用less和gulp. 因为也是初学gulp,站点的文件结构还没想到太好,也只是 ...

随机推荐

  1. UGUI双击事件

    经测试在Android.ios平台下无效 using UnityEngine; using UnityEngine.EventSystems; using System.Collections; us ...

  2. adb的一些常用的命令

    如果在dos界面想要直接用adb的话,需要将anroidsdk安装目录下的tools和platform-tools以及加入到环境变量path中. 查看当前的设备(包括真机和模拟器):adb devic ...

  3. 02 Tensorflow的安装配置

    1 anaconda 64 位,win10 安装 清华大学镜像网络,下载地址:https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/ 选择下载文件 ...

  4. JavaScript实现AOP(面向切面编程,装饰者模式)

    什么是AOP? AOP(面向切面编程)的主要作用是把一些跟核心业务逻辑模块无关的功能抽离出来,这些跟业务逻辑无关的功能通常包括日志统计.安全控制.异常处理等.把这些功能抽离出来之后, 再通过“动态织入 ...

  5. kubectl 获取信息

    获取pod所在节点的ip kubectlget po tiller-deploy-8694f8fddc-c2rql -n kube-system -o jsonpath='{.status.hostI ...

  6. ccf认证模拟题之三---最大的矩形

    问题描述 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i(1 ≤ i ≤ n)个矩形的高度是hi.这n个矩形构成了一个直方图.例如,下图中六个矩形的高度就分别是3, 1, 6, 5, 2, 3 ...

  7. ftp使用(图文详解)

    41,准备: FileZilla_Server-v0.9.41.rar 2.安装,可以全部默认下一步 这里装在了E盘 3安装成功添加用户 添加用户名yanan 选择share folders选择要共享 ...

  8. gridiew列求和,表的列求和,表的记录数,时间段查询

    下面求的是gridview中第5列的值,并在lable1中显示 protected void Page_Load(object sender, EventArgs e)    {        int ...

  9. Swift 项目中可能用到的第三方框架

    这里记录下swift开发中可能用的框架 , 最近浏览了不少,积累在这里,以后用的时候方便查阅.顺便推荐给大家! 这里的框架都是纯swift的 , 感谢开源 ,感谢大神们 . 下拉刷新 BreakOut ...

  10. Kuberentes-入门

    一.kubernetes架构介绍和集群规划 点击链接查看: 系统环境初始化:https://www.cnblogs.com/hwlong/p/9105742.html 二.CA证书创建和分发 点击链接 ...