技术研究之gulp

标签: Gulp 分类: Nodejs 创建时间:2019-05-31 07:42:36 更新时间:2025-01-17 10:39:23

1.安装gulp

先是全局安装:npm install gulp -g,然后在本地安装npm install gulp –save-dev,这里建议使用cnmp,使用npm可能会报一些莫名奇妙的错误。

2.安装child_process

npm install child_process –save-dev; child_process是什么作用(作用很大,安,就完事了),主要执行子进程的命令行工具。
## 安装gulp-sequence
npm install gulp-sequence –save-dev; 随着慢慢的使用和学习,就知道了要想玩的溜,就要不停的安装插件,配合插件才能更好的执行gulp命令。gulp-sequence主要是为了让gulp命令能按顺序执行。

如果安装了gulp4.0版本,执行gulp-sequence会出现问题,提示:typeerror gulp.on(…).on(…).on(…).on(…).start is not a function gulp-sequence

这里主要是因为在gulp4中提供了gulp.series和gulp.parallel方法,这个时候就要使用gulp.series代替gulp-sequence模块了,类似于下面的内容。

1
2
3
4
5
//  默认  gulp 命令推送到仓库  (如需自定义 commit  执行  gulp -a 自定义commit)
gulp.task( 'default', gulp.series( 'back','add','commit', 'push',function(){
console.log("压缩打包完成");
}));

3.安装minimist

npm install minimist –save-dev; minimist轻量级的命令行解析工具。使用方式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
//命令行中输入
gulp default -a "修改gulpfile"

//获取命令行参数
var argv = require('minimist')(process.argv.slice(2));
//输出参数
console.log(argv);
//结果别解析为一个对象
{ _: [ 'default' ], a: '修改gulpfile' }
//这个时候就可以直接使用
console.log(argv.a)
//输出结果为
'修改gulpfile'
//当然,你可以将 -a 换成其他的有意思的key,比如 -b
console.log(argv.b)
//就可以获取-b后边的内容,还可以继续添加
gulp default -a "修改gulpfile" -b "dss"
console.log(argv)
//输出
{ _: [ 'default' ], a: '修改gulpfile', b: 'dss' }

4.编写gulpfile.js文件

在本地(本地是哪个地方,自己琢磨,主要就是你本地安装gulp的那个地方)添加gulpfile.js文件,里面写一些任务,next中添加的是gulpfile.coffee文件,这个主要是用了coffee语法,需要安装coffee-script,具体怎么操作,喜欢coffee语法的朋友可以自行谷歌。

5.运行gulp命令

在命令行中直接写gulp命令就好了,gulp会自动查找当前目录下的gulpfile.js文件然后执行里面的default任务。

小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。