如何利用node.js开发一个生成逐帧动画的小工具

2019-12-15     科技i关注



前言

在实际工作中我们已经下下来不下于一万个npm包了,像我们熟悉的vue-cli,react-native-cli等,只需要输入简单的命令vueinitwebpackproject,即可快速帮我们生成一个初始项目。在实际开发项目中,我们也可以定制一个属于自己的npm包,来提高自己的工作效率。

为什么要开发一个工具包?

这次以帧动画工具为例,来一步一步解析如何开发一个npm包。

开始前的准备

以我们这次为例。由于目前在做一些活动页相关的工作,其中动画部分全都采用CSS3中的animation来完成,但是这样每次开发都要计算百分比,手动判断动画的一些属性值,十分耗时又很容易出错,就想能不能写个脚本,直接一行命令就可以搞定了呢?!答案当然是肯定的。

理清思路

我们要做一个可以通过读取图片就可以自动生成包含CSSanimation的HTML页面,以后需要生成相应的CSS片段,直接执行命令就可以了。

初始化

既然是npm包,那我们就需要在npmjs上注册一个账号,注册完成之后回到本地新建一个文件目录fbf,进入fbf目录下执行npminit-y。


这样,你的package.json就建好了。

依赖的库

来看看会用到哪些库。


命令行操作

node.js内置了对命令行操作的支持,在package.json中的bin字段可以定义命令名和关联的执行文件。所以现在package.json中加上bin的内容:


然后在index.js中来定义start命令:


调用version('1.0.0','-v,--version')会将-v和--version添加到命令中,可以通过这些选项打印出版本号。

调用command('start')定义start命令,name则是必传的参数,为文件名。

action()则是执行start命令会发生的行为,要生成项目的过程就是在这里面执行的,这里暂时只打印出name。

其实到这里,已经可以执行start命令了。我们来测试一下,在fbf的同级目录下执行:


可以看到命令行工具也打印出了HelloWorld,那么很清楚,action((name)=>{})这里的参数name,就是我们执行start命令时输入的项目名称。

命令已经完成,接下来就要针对图片的操作了。

获取图片信息

这里我们默认根据第一张图片的尺寸信息作为外层DIV的默认尺寸。


生成CSS代码

然后根据图片数量生成相应的keyframes代码


生成html文件

最后我们把生成的CSS放到HTML里。


视觉美化

通过chalk来为打印信息加上样式,比如成功信息为绿色,失败信息为红色,这样子会让用户更加容易分辨,同时也让终端的显示更加的好看。


完整示例


代码一共100行左右,可以说非常简单明了,有兴趣的同学可以试试。

最后

完成之后,使用npmpublishfbf就可以把脚手架发布到npm上面,通过-g进行全局安装,就可以在自己本机上执行fbfstart[dir]来生成一个fbf.html文件,这样便完成了一个简单的node工具了。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对小编的支持。

文章来源: https://twgreatdaily.com/zh-hans/U3qihW8BMH2_cNUgusJA.html