gulp开发简单配置以及配合browserify应用

简介: 前端开发都需要对css ,js 打包压缩,less 编译,gulp简单的风格,可以完美的完成这项任务。

前端开发都需要对css ,js 打包压缩,less 编译,gulp简单的风格,可以完美的完成这项任务。

首先需要安装gulp 

npm install gulp -g

npm install gulp --save-dev

安装gulp 需要的插件 如下

npm install gulp-***  --save-dev

var uglify = require('gulp-uglify');        //js混淆 min
var less = require('gulp-less');        // less 编译
var sourcemaps = require('gulp-sourcemaps');        //生成sourcemap文件 方便less 文件关系
var cssmin = require('gulp-minify-css')     // css min
var livereload = require('gulp-livereload'); // 自动刷新  免除f5 
项目根目录下新建 gulifile.js 文件

首先 需要对less 编译 压缩

//定义一个guleLess任务(自定义任务名称)
gulp.task('guleLess', function () {
    gulp.src('public/src/less/**/*.less') //该任务针对的文件 less
        .pipe(sourcemaps.init())    // less map 初始化
        .pipe(streamify(less())) //该任务调用的模块
        .pipe(cssmin()) //css 缩写
        .pipe(sourcemaps.write({addComment: false}))
        .pipe(gulp.dest('public/style')); //将会在src/css下生成index.css
});

对应目录,如下


 

addComment: false 生产的css ,或者js 里是否有描述


gulp 启动 和 代码变化监听

//监听文件变化
gulp.task('watchs', function() {
    livereload.listen(); // 浏览器刷新
    gulp.watch('public/src/*', ['guleLess', 'javascript']);
});
// cmd gulp
gulp.task('default',['watchs', 'guleLess', 'javascript']); 

js 压缩混淆

gulp.task('javascript', function() {
    gulp.src('public/src/javascripts/**/*.js')
        .pipe(sourcemaps.init())
        .pipe(uglify())
        .pipe(sourcemaps.write())
        .pipe(gulp.dest('public/javascripts'));
});




当然可以把 要做webapp 时 就可以把 js 全部压缩到一个js里,同时需要gulp和browserify结合,添加如下包

var browserify = require('browserify');
var source = require('vinyl-source-stream'); //将Browserify的bundle()的输出转换为Gulp可用的一种虚拟文件格式流
var streamify = require('gulp-streamify');  //只支持 buffer 的插件直接处理 stream

gulp.task('javascript', function() {

    var b = browserify();
    //文件路径
    files = ['public/src/javascripts/reg/index.js',
             'public/src/javascripts/login/index.js'];

    files.forEach(function(item){
        b.add(item);
    });
    b.bundle().pipe(source('public/javascripts/packages.js'))
        .pipe(streamify(uglify()))
        .pipe(gulp.dest('./'));
});


d.add 可以换成require 就是 压缩 需要的 模块插件到一个js里  修改如下

  files = ['jquery'];

    files.forEach(function(item){
        b.require(item);
    });

新年第一天以一篇博结束,祝大家新年快。





有需要的交流的可以加个好友


相关文章
|
2月前
|
JavaScript 前端开发 API
Node.js 工具库 yeoman 的作用介绍
Node.js 工具库 yeoman 的作用介绍
33 0
|
8月前
|
JSON 小程序 前端开发
小程序引入第三方插件Vant和小程序WeUl组件库
现如今前端的技术再向框架化的发展,框架的使用提高我们的编码的效率和性能的优化,同样CSS样式也是越来越高的要求,今天我要向大家介绍的就是较火的前端UI框架Vant UI组件库
196 0
|
9月前
|
JavaScript API 开发者
为依赖Angular.js的上古项目给VSCode编写$scope定义跳转扩展插件
虽然Angular.js停止更新已经一年了,但依赖它的上古时代的项目并不少。由于都是使用js开发,很难为其提供很好的维护,所以直到今天开发维护也并不愉快。可以说没有开发插件的支持,再成熟老练的框架都发挥困难。
119 0
为依赖Angular.js的上古项目给VSCode编写$scope定义跳转扩展插件
|
10月前
|
JavaScript 前端开发 开发工具
从0搭建Vue3组件库:使用gulp自动化处理打包与发布
从0搭建Vue3组件库:使用gulp自动化处理打包与发布
304 0
|
10月前
|
JavaScript 前端开发
前端工程化的Node.js之代码的组织/部署的模块 module
随着前端项目越来越复杂,前端工程化变得愈加重要。Node.js 作为前端工程化的重要组成部分,其模块机制在代码的组织和部署方面扮演了至关重要的角色。
64 0
|
10月前
|
存储 前端开发 JavaScript
前端工程化的Node.js之代码的组织/部署的包 package
在现代的Web开发中,前端工程化已经成为了不可或缺的一部分。而Node.js作为JavaScript的运行环境,为前端工程化提供了很多强大的工具和支持。其中,代码的组织和部署是前端工程化中非常重要的一部分,而Node.js的包管理系统npm就是解决这个问题的利器。今天我们就来探讨一下如何使用npm来进行代码的组织和部署。
65 0
|
10月前
|
存储 缓存 JSON
【脚手架】从0到1搭建React18+TS4.x+Webpack5项目(二)基础功能配置
【脚手架】从0到1搭建React18+TS4.x+Webpack5项目(二)基础功能配置
|
缓存 JSON Rust
|
JavaScript 前端开发
js 模块化基础和模块规范AMD、CMD、ES6模块
js 模块化基础和模块规范AMD、CMD、ES6模块
88 0
|
资源调度 JavaScript 前端开发
「使用 webpack 5 从0到1搭建React + TypeScript 项目环境」3. 资源模块
「使用 webpack 5 从0到1搭建React + TypeScript 项目环境」3. 资源模块
「使用 webpack 5 从0到1搭建React + TypeScript 项目环境」3. 资源模块