设为首页 收藏本站
查看: 1361|回复: 0

[经验分享] gulp前端自动化构建工具新手入门篇

[复制链接]

尚未签到

发表于 2017-2-25 09:51:02 | 显示全部楼层 |阅读模式
  很久没有更新博文了。
  经过了一次年前吐血的赶项目,终于在年后回血了。趁着有空,新学到了一个前端自动化构建工具-gulp。
  现在我们通过这3个问题来学习一下;


1、什么是gulp?

2、为什么要用gulp?

3、怎么用?



什么是gulp

答:是一个前端自动化的构建工具,直白点说,如果没有这个工具,我们利用人工依旧可以做到以下优点,但是在项目逐渐庞大的时候,采用这个工具,可以提升性能和效率。



为什么要用gulp?

答:

1、js和css属于静态文件,很多时候浏览器存在缓存机制,为了避免缓存带来的误会,可以利用构建工具,给每一个静态文件添加一个版本号,这样浏览器就会认为是新的文件,就不存在缓存机制。

2、性能优化:文件合并,减少http请求;文件压缩,减少文件体积,加快下载速度;

3、效率提升:自动添加CSS3的vendor前缀;代码分析检查改正;在使用MVC和MVVM的框架后,可在提交之前,使用gulp自动跑一遍单元测试;



怎么用?

1、首先,安装gulp之前,先安装nodejs环境,因为gulp是基于nodejs的前端构建工具




$ npm install --global gulp

2、然后,在开发项目上,安装项目依赖(devDependencies)




$ npm install --save-dev gulp

3、继续,在项目的根目录下创建一个名为:gulpfile.js的文件,用来配置gulp的相关task:




$ touch gulpfile.js

  --请打开gulpfile.js,输入以下内容:

    


var gulp = require('gulp');

  这行命令告知node,先局部(node_modules)查找gulp包,找不到再去全局查找。找到之后就会赋值给gulp变量,然后我们就可以使用它了。
  --如何配置gulp任务:



gulp.task('task-name',funcion(){
//Stuff here
});

  这是gulp设置task的大概模版,'task-name'是你给任务起的名字,稍后在命令行执行gulp task-name,将任务执行。
  写个hello world,是这样的
   DSC0000.jpg    
  然后在命令行执行



$ gulp hello

  运行结果:
DSC0001.jpg

  好的,已经成功运行出来了!大概任务就是这样子,现在我们来写一个正式的gulp任务。
  例如,编译sass,任务代码为:
DSC0002.jpg

  如图:.src 是文件的源路径;.pipe是任务运行的管道;.dest是任务结束之后的输出路径。
  同时sass文件内容为,下面那个分数没有被计算出来:
DSC0003.jpg

  好的,代码写完了,在命令行执行命令 $ gulp sass,如图:
DSC0004.jpg

  编译后,你在css输出的路径那里会看到生成了一个同名的.css文件,内容就是sass编译完的结果为:
DSC0005.jpg

  gulp还有很多其它插件,例如:压缩,合并,加vendor前缀(css3对各个浏览器兼容的前缀)等等功能,都跟以上做法类似。


补充:

1、*.scss :*号匹配当前目录任意文件,所以这里的*scss匹配当前目录下所有scss文件。

2、**/*.scss:匹配当前目录及其子目录的所有scss文件。

3、!not-me.scss:!号移除匹配的文件,这里将移除not-me.scss

4、*.+(scss|sass):+号后面会跟着圆括号,里面的元素用|分割,匹配多个选项,这里将匹配scss和sass文件。



gulp的基本用法大概就是这样,他还有很多其它插件,可以方便开发,例如自动刷新,监听事件之类的等等,下面就是常用插件的链接:


No.1、run-sequence
  Links: https://www.npmjs.com/package/run-sequence
  作用:让gulp任务,可以相互独立,解除任务间的依赖,增强task复用

No.2、browser-sync
  Links: http://www.browsersync.io/
  作用:静态文件服务器,同时也支持浏览器自动刷新

No.3、del
  Links:https://www.npmjs.com/package/del
  作用:删除文件/文件夹

No.4、gulp-coffee
  Links: https://github.com/wearefractal/gulp-coffee
  作用:编译coffee代码为Js代码,使用coffeescript必备

No.5、coffee-script
  Links: https://www.npmjs.com/package/coffee-script
  作用:gulpfile默认采用js后缀,如果要使用gulpfile.coffee来编写,那么需要此模块

No.6、gulp-nodemon
  Links: https://www.npmjs.com/package/gulp-nodemon
  作用:自动启动/重启你的node程序,开发node服务端程序必备

No.7、yargs
  Links: https://www.npmjs.com/package/yargs
  作用:用于获取启动参数,针对不同参数,切换任务执行过程时需要

No.8、gulp-util
  Links: https://www.npmjs.com/package/gulp-util
  作用:gulp常用的工具库

No.9、gulp-uglify
  Links: https://www.npmjs.com/package/gulp-uglify
  作用:通过UglifyJS来压缩JS文件

No.9、gulp-concat
  Links: https://www.npmjs.com/package/gulp-concat
  作用:合并JS

No.10、gulp-sourcemaps
  Links: https://www.npmjs.com/package/gulp-sourcemaps
  作用:处理JS时,生成SourceMap

No.11、gulp-less
  Links:https://www.npmjs.com/package/gulp-less
  作用:将less预处理为css

No.12、gulp-sass
  Links:https://www.npmjs.com/package/gulp-sass
  作用:将sass预处理为css
  No.13、gulp-autoprefixer
  Links:https://www.npmjs.com/package/gulp-autoprefixer
  作用:使用Autoprefixer来补全浏览器兼容的css。

No.14、gulp-minify-css
  Links:https://www.npmjs.com/package/gulp-minify-css
  作用:压缩css。

No.15、connect-history-api-fallback
  Links:https://www.npmjs.com/package/connect-history-api-fallback
  作用:开发angular应用必须,用于支持HTML5 history API.






相关链接:

gulp官方网站:http://gulpjs.com/

gulp中文网站:http://www.gulpjs.com.cn/docs/

参考资料链接:

http://www.w3ctrain.com/2015/12/22/gulp-for-beginners/

http://www.mamicode.com/info-detail-517085.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-346894-1-1.html 上篇帖子: JavaScript中异步编程 下篇帖子: unofficial 专注于学习分享的www.unofficial.cn
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表