gulp基于seaJs模块化项目打包实践
2017-05-15 15:28
501 查看
一:devDependencies依赖
了解gulp的肯定对npm都有所了解,在这里就不再赘述,直接贴依赖包。"devDependencies": { "gulp": "^3.9.1", "gulp-autoprefixer": "^3.1.1", "gulp-clean": "^0.3.2", "gulp-cleanhtml": "^1.0.1", "gulp-cssimport": "^5.0.0", "gulp-cssmin": "^0.1.7", "gulp-htmlmin": "^3.0.0", "gulp-load-plugins": "^1.5.0", "gulp-rename": "^1.2.2", "gulp-rev": "^7.1.2", "gulp-rev-collector": "^1.1.1", "gulp-seajs-combo": "^1.2.3", "gulp-uglify": "^2.1.0" }
二: css的压缩、合并、md5
文件中使用了gulp的插件“gulp-load-plugins”,没用过的可以简单了解下 https://www.npmjs.com/package/gulp-load-plugins[code]//css 合并 压缩 md5gulp.task('css', function(){ return gulp.src('./public/static/src/css/!(common|lib)/*.css') .pipe($.cssimport({})) .pipe($.autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1', 'ios 6', 'android 4')) .pipe($.cssmin()) .pipe($.rev()) .pipe(gulp.dest('./public/static/dist/css')) .pipe($.rev.manifest()) .pipe($.rename('css-mainfest.json')) .pipe(gulp.dest('./public/static/dist/rev/css'));});考虑到每次修改需要把以前的css文件删除,所以还要有清除css文件的任务//清除原来的内容gulp.task("cleancss", function(){ return gulp.src('./public/static/dist/css') .pipe($.clean());});
三: seajs合并
好了,下面是重头戏--合并seajs,在合并seajs之前,我们先了解下一些不同的地方。由于打包的局限性我们需要给每一个被页面引入的seajs文件添加一个中介文件调用seajs.use,不要在页面中使用seajs.use调用。Demo如下:// seajs合并gulp.task('seajs', ['index/index', 'index/submit','require/index']);gulp.task('index/index', function(){ return gulp.src("./public/static/src/js/{index,}/index_main.js") .pipe($.seajsCombo({ map:{ '/static/src/js/index/index.js': 'D:/wamp/www/hxe/js/index/index.js' } })) .pipe(gulp.dest('D:/wamp/www/hxe/temp'))});gulp.task('index/submit', function(){ return gulp.src("./public/static/src/js/{index,}/submit_main.js") .pipe($.seajsCombo({ map:{ '/static/src/js/index/submit.js': 'D:/wamp/www/hxe/js/index/submit.js' } })) .pipe(gulp.dest('D:/wamp/www/hxe/temp'))});gulp.task('require/index', function(){ return gulp.src("./public/static/src/js/{require,}/schedule_main.js") .pipe($.seajsCombo({ map:{ '/static/src/js/require/index.js': 'D:/wamp/www/hxe/js/require/index.js' } })) .pipe(gulp.dest('D:/wamp/www/hxe/temp'))});在这里重点强调一下,由于打包的一些限制,我们需要将js文件夹复制一份放到一个绝对路径文件夹下,我在这放到了
D:/wamp/www/hxe/下,而我们产生的合并文件也一并存放在这个文件夹下。还需要注意的一点是我们在一个项目肯定会存在不同的文件夹下有相同的文件名,如我的项目在index和require文件夹下都存在
index_main.js和
index.js这就需要我们用正则区分,即上面的
{index,}和
{require,}。
四: js压缩
熟悉gulp的肯定知道我们只有在seajs合并任务完毕后才能执行压缩任务,所以我们可以将
seajs任务作为
js的前置任务。
// 压缩jsgulp.task('js', ['seajs'], function(){ return gulp.src("D:/wamp/www/hxe/temp/*/*.js") .pipe($.uglify({ mangle: { except: ['require', 'exports', 'module', '$'] }//排除混淆关键字 })) .pipe($.rev()) .pipe(gulp.dest('./public/static/dist/js')) .pipe($.rev.manifest()) .pipe($.rename('js-manifest.json')) .pipe(gulp.dest('./public/static/dist/rev/js'))});//清除原来的内容gulp.task("cleanJs", function(){ return gulp.src('./public/static/dist/js') .pipe($.clean());});在这里,就需要将我们再绝对路径下合并产生的临时文件压缩并输出到我们的项目路径下。
五: html压缩
html的操作,最主要的重头戏还是在于css和js的路径替换,所以打包的成功与否html这边的操作也至为重要。//html 压缩gulp.task('rev',['css','js'],function () { var options = { removeComments: true, //清除HTML注释 collapseWhitespace: true, //压缩HTML collapseBooleanAttributes: true, //省略布尔属性的值 input checked="true" ==> input checked removeEmptyAttributes: true, //删除所有空格作属性值 input id="" ==> input removeScriptTypeAttributes: true, //删除<script>的type="text/javascript" removeStyleLinkTypeAttributes: true, //删除<style>和<link>的type="text/css" minifyJS: true, //压缩页面JS minifyCSS: true //压缩页面CSS }; return gulp.src(['./public/static/dist/rev/*/*.json', './application/home/view/**/*.html']) .pipe($.revCollector({ replaceReved: true, dirReplacements: { '/src/css': '/dist/css/', '/src/js/': '/dist/js/' } })) .pipe($.htmlmin(options)) .pipe(gulp.dest('./application/home/view_build')); });//清除html文件夹gulp.task("cleanhtml", function(){ return gulp.src('./application/home/view_build') .pipe($.clean());});
六: 程序的默认执行
程序的默认执行,主要是对gulp打包的顺序最后做一遍确认,在控制台直接使用gulp就能触发default任务。
//默认任务gulp.task('default', ['cleancss','cleanJs', 'cleanhtml'], function(){ gulp.start('rev');});
相关文章推荐
- gulp基于seaJs模块化项目打包实践【原创】
- 基于CocoaPods的iOS项目模块化实践
- 前端项目模块化的实践2:使用 Webpack 打包基础设施代码
- 基于maven的javaweb项目模块化开发
- Eclipse多项目依赖工程基于Gradle的多渠道打包脚本
- 一、东软实践项目2-基于android平台的应用开发:实现页面之间的跳转
- 二、东软实践项目2-基于android平台的应用开发:简单用户登陆
- Asp.Net大型项目实践(11)-基于MVC Action粒度的权限管理【续】【源码在这里】(在线demo,全部源码)
- gulp打包seajs,用gulp-cmd-pack打包seajs模块
- 一个基于SSH的实践项目在开发过程中遇到的问题汇总
- 初学seaJs模块化开发,利用grunt打包,减少http请求
- 基于构件技术的软件工程 - Small Team Practice小型团队项目实践标准
- 基于ant集成打包,生成native exe 的项目配置方法。
- 基于restful风格的maven项目实践(融合spring)
- SeaJS 前端模块化开发探索与网站性能优化实践
- Asp.Net大型项目实践(10)-基于MVC Action粒度的权限管理(在线demo,全部源码)
- 精通JSF:基于EJB、Hibernate、Spring整合开发与项目实践 --我的第一本合著书终于出版了
- 前端模块化实践——seajs的使用
- 基于NODEJS的前后端项目分离实践