源文件编译css
这里我使用的工具是grunt,他自己主要是基于Node.js的文件操做包,其中有许多插件可让咱们完成js文件的compile和compress、sass到css的转换等等操做。要使用它须要先安装命令行工具:npm install grunt-cli -g
,而后在项目根目录中建立文件Gruntfile.js
,这个文件用于定义各类task,咱们首先定义一个task将从bower下载的第三方依赖都打包到文件app/js/lib.js
中:html
这里的grunt-contrib-concat就是grunt的一个插件,用于文件的合并操做,咱们已经在前面的package.json
中引入了。js
是task name;src
指定了合并的源文件地址;dest
指定了合并的目标文件。这样当咱们运行grunt concat:js
后,全部的依赖文件都会被合并为app/js/lib.js
。这样作的好处是咱们能够控制每一个依赖的引入顺序,可是麻烦的是每次引入新的依赖都须要手动加入到dependencies
数组中。这个暂时没有更好的解决方案,由于不是全部的包都在本身的components.js
中声明了main文件,不少时候必须本身手动指定。前端
JavaScript文件编译完成之后就是CSS文件,在现代的前端开发中,咱们已经不多直接写CSS文件了,通常都使用SASS或者LESS。grunt也提供了这种支持,这里我使用的是grunt-contrib-compass:node
而后运行grunt compass:development
就能够完成CSS文件的编译了。jquery
自动化测试git
这里我使用的自动化测试工具是Jasmine,它grunt中一样有一个插件:grunt-contrib-jasmine。下面咱们来看看如何在Gruntfile.js
中定义测试的task:github
配置完成之后就能够运行grunt jasmine:test
来跑测试,但问题是每次写完代码都要手动执行一次很是麻烦,最好能够每次代码有更改都自动跑一次,让咱们能够更快的获得反馈。grunt的watch插件就提供了这种支持:npm
files
指定了须要监听变更的文件;tasks
指定了修改后自动触发的task。如今只要咱们运行grunt watch:test
,那么有任何源文件、测试文件的改动,Jasmine测试都会自动运行了。有时候咱们也但愿测试的结果显示在网页上,便于咱们作js的调试。那么能够将tasks:['jasmine:test']
改成tasks: ['jasmine:test:build']
,而后打开根目录下的_SpecRunner.html
文件,就能够在网页中看到测试结果了,再加上一些Chrome的Livereload插件,就能够不用刷新实时的看到测试结果,效率很是之高。虽然grunt插件中也有livereload,可是与grunt-contrib-watch没法很好的集成,因此我没有使用这种方式。json
CI Pipeline后端
因为个人项目是host在github上,因此我选择travis-ci做为个人CI服务器。要启用travis-ci须要如下几步:
.travis.yml
到github,触发第一次build。package.json
的scripts
项,指定运行测试的命令下面咱们来看看如何配置.travis.yml
:
因为咱们的环境是基于Node.js搭建的,因此在language设置了nodejs;而**nodejs指定了Node.js的版 本;before_script**指定了在测试运行前须要执行的命令,因为咱们的脚本都是基于grunt的,因此须要先安装grunt的命令行包。
而后再修改package.json
:
将修改之后的package.json
push到github上,再次触发一个新的build,你能够看到你以前错误的build已经绿了。
这里还有一个小提示:如何让build状态显示在项目的readme中?很简单,只须要在README.md中加入如下代码就能够了:
到这里基本的环境搭建就完成了,固然咱们还可使用grund的registerTask
来定义一个任务序列,还能够加 入template的编译⋯⋯这些均可以经过grunt来灵活设置。最重要的是如今别人拿到一个项目的代码之后,能够经过一些命令来快速的搭建本地环境, 方便的进行测试和开发,并且没有依赖与后端的开发环境,只要定义好接口,前端开发能够彻底独立开了。虽然这其中还有不少问题没有解决,例如:
package.json
与components.json
其实有些重复这正是因为如今前端开发环境尚未后端开发的那种标准化,也正是挑战和机遇之所在!