- 本地开发支持环境
- 静态文件编译 css / js
- 组件源服务
- 开发辅助工具等
- 版本需大于 0.6
- windows: http://nodejs.org/dist/v0.8.15/node-v0.8.15-x86.msi
- mac: http://nodejs.org/dist/v0.8.15/node-v0.8.15.pkg
- linux: 自行使用 apt-get(ubuntu) 或 yum(centos) 安装
- windows: 使用Slik SVN, http://www.sliksvn.com/en/download
- mac: 自带 或使用 port 安装
- linux: 自行使用 apt-get(ubuntu) 或 yum(centos) 安装
- 如不安装, 可能会影响 sync 命令的使用
- windows: http://optics.ph.unimelb.edu.au/help/rsync/rsync_pc1.html#install
- mac: 自带
- linux: 自带
- 请自行配置免密码ssh登录
npm install fekit -g
npm config set user 0
npm config set unsafe-perm true
fekit {命令名} --help
{
// 编译方案, 参考 [issue #1](https://github.com/rinh/fekit/issues/1)
"compiler" : false 或 "modular" 或 "component" ,
// 如果是组件,需要有如下节点
"name" : "hello1" , // 组件名称
"version" : "0.0.1" , // 遵循semver
"author" : "rinh" , // 作者名
"email" : "[email protected]" , // 作者邮箱
"description" : "" , // 组件描述
"main" : "home" , //指定某个文件作为包入口, 该路径以src目录为根. 默认使用 src/index
// 依赖的组件
"dependencies" : {
"dialog" : "1.2.*"
} ,
// 别名的配置, 该库作为编译时, @import url 和 require 使用
"alias" : {
"core" : "./src/core" /* 该路径相对于当前fekit.config文件 */
} ,
// 在本地开发时(fekit server),需要用到的一些配置
"development" : {
// 自定义依赖解决方案
// 指向一个js脚本,运行环境是 nodejs
// 请指定入口函数为 exports.render = function( context )
// context 内容为:
// {
// type : 'javascript 或 css' , 文件类型
// path : '..' , 当前文件的物理路径
// url : '..' , 当前文件的引用路径
// base_path : '..' , 当前文件的父级物理路径
// }
"custom_render_dependencies" : "./build/runtime.js"
} ,
// 将要导出至 `prd` 和 `dev` 目录的文件列表
// 其中所有路径, 均相对于 `src` 目录
"export" : [
// 第一种配置方式, 直接写出要导出的文件相对路径
"./scripts/page-a.js" ,
// 第二种配置方式, 当要导出的文件, 在实际使用时有上级依赖, 则可以将上级依赖的文件加入`parents`节点
{
"path" : "./scripts/page-b.js" ,
"parents" : [ "./scripts/page-a.js" ]
} ,
// 允许某个文件不含版本号信息
// 参考: https://github.com/rinh/fekit/issues/11
{
"path" : "./scripts/page-c.js" ,
"no_version" : true
}
] ,
// 自动化hook脚本, 请参考 https://github.com/rinh/fekit/issues/10 , https://github.com/rinh/fekit/issues/12
"scripts" : {
"premin" : "./build/premin.js" ,
"postmin" : "./build/premin.js" ,
"prepack" : "./build/premin.js" ,
"postpack" : "./build/premin.js" ,
"prepublish" : "./build/prepublish.js"
} ,
// 自定义编译参数
"min" : {
"config" : {
// 参数名及含义见: https://github.com/fmarcia/UglifyCSS
"uglifycss" : {} ,
// 参数名及含义见: https://github.com/mishoo/UglifyJS
"uglifyjs" : {
"ast_mangle" : {} ,
"ast_squeeze" : {} ,
"gen_code" : {}
}
}
}
}
fekit是一个插件化, 易于扩展的工具集, 如果你愿意为它增加功能, 请看下面的内容
开发外部扩展请使用 fekit extension template
fekit所有源码全部使用coffeescript开发
- bin - 放置可执行文件
- lib - 执行代码(编译结果,请不要修改)
- src - 源码
- test - 单元测试
- testcase - 测试用例, 模拟了一个真实项目的case
- Cakefile - 部署文件
请在src/commands
增加文件 {命令名}.coffee
一个命令请包含如下内容
# 命令的使用说明
exports.usage = "使用说明"
# 命令的参数定义, 请参考optimist的使用方法
exports.set_options = (optimist) ->
# 命令入口
exports.run = (options) ->
请在src/compiler/plugins
增加文件 {编译处理后缀名}.coffee
其中必须存在的方法是
# 决定该编译方式是用于哪类处理
exports.contentType = "javascript 或 css"
# 处理方法
# @source 待处理文件的内容
# @path 待处理文件的路径
# @callback( err , result ) 处理完成的回调
# 返回结果应该编译结果
exports.process = ( source , path , callback ) ->