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);
    });

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





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


相关文章
|
6月前
|
前端开发 JavaScript 开发者
Angular与Webpack协同优化:打造生产级别的打包配置——详解从基础设置到高级代码拆分和插件使用
【8月更文挑战第31天】在现代前端开发中,优化应用性能和加载时间至关重要,尤其是对于使用Angular框架的项目。本文通过代码示例详细展示了如何配置Webpack,以实现生产级别的打包优化。从基础配置到生产环境设置、代码拆分,再到使用加载器与插件,每个步骤都旨在提升应用效率,确保快速加载和稳定运行。通过这些配置,开发者能更好地控制资源打包,充分发挥Webpack的强大功能。
210 0
|
JavaScript
nodejs下用es6编程babel和gulp的配合应用
每一个程序员都有一颗全栈的心,node和es6满足了尤其是前端的憧憬。 node下用express框架,实现一个简单的mvc。
1041 0
|
6月前
|
JavaScript PHP 开发者
PHP中的异常处理与自定义错误处理器构建高效Web应用:Node.js与Express框架实战指南
【8月更文挑战第27天】在PHP编程世界中,异常处理和错误管理是代码健壮性的关键。本文将深入探讨PHP的异常处理机制,并指导你如何创建自定义错误处理器,以便优雅地管理运行时错误。我们将一起学习如何使用try-catch块捕获异常,以及如何通过set_error_handler函数定制错误响应。准备好让你的代码变得更加可靠,同时提供更友好的错误信息给最终用户。
webpack配置篇(三十二):使用ESLint规范构建脚本
webpack配置篇(三十二):使用ESLint规范构建脚本
162 0
webpack配置篇(三十二):使用ESLint规范构建脚本
|
JSON JavaScript 前端开发
JXcore 打包在企业级项目里的合理运用和模块系统以及网络的配置详解【node.js】
JXcore 打包在企业级项目里的合理运用和模块系统以及网络的配置详解【node.js】
JXcore 打包在企业级项目里的合理运用和模块系统以及网络的配置详解【node.js】
|
6月前
|
前端开发 开发者
在前端开发中,webpack 作为模块打包工具,其 DefinePlugin 插件可在编译时动态定义全局变量,支持环境变量定义、配置参数动态化及条件编译等功能。
在前端开发中,webpack 作为模块打包工具,其 DefinePlugin 插件可在编译时动态定义全局变量,支持环境变量定义、配置参数动态化及条件编译等功能。本文阐述 DefinePlugin 的原理、用法及案例,包括安装配置、具体示例(如动态加载资源、配置接口地址)和注意事项,帮助开发者更好地利用此插件优化项目。
189 0
|
JavaScript 网络架构 索引
JS 高级(六)ES6的特性与功能
JS 高级(六)ES6的特性与功能
184 0
JS 高级(六)ES6的特性与功能
|
JavaScript Shell Linux
Node.js中的express框架,修改内容后自动更新(免重启),express热更新
Node.js中的express框架,修改内容后自动更新(免重启),express热更新
|
9月前
|
JavaScript 前端开发 应用服务中间件
angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
angular引入包、路由权限配置、打包问题与nginx配置问题(简单部署)
209 0
谈谈webpack对npm模块导入的解析
问题描述 在一次运营后台的常规更新时,发现有一个外部依赖包不能正常工作。经排查发现,react-split-pane在前几天发了一个新版0.1.81,该版本同时提供commonjs和es module两种包导入方式:   原来我们采用的CMD写法 const ReactSplitPane = require('react-split-pane') 失效了。 
1713 0

热门文章

最新文章