Kraken.js!
Hello Kraken.js!
前言
kraken.js 由paypal 公司开源的一个用于快速开发基于Express.js框架应用的快速开发工具, 因为kraken 并没有在Express.js基础上更改多少东西,只是在原来的express基础上补充了一些约定开发的规则, 让开发根据便捷.
你好,世界!
要创建一个kraken 项目只需要非常简单的三步走:
安装必备工具
Linux or Mac
sudo npm install -g generator-kraken
Windowsnpm install -g generator-kraken
创建kraken项目
只需要一行代码,然后,看着提示语,输入一些东西,一个项目就这样创建完毕.yo kraken
运行kraken项目
还是只需要一行代码npm start
以上三行代码即可,完成一个kraken项目的创建了.
注意事项:
yo kraken
你输入项目名字的时候,会在当前项目创建与该项目名字一样的文件夹,记得cd
进去文件夹再去运行npm start
注意
NODE_ENV
的设置,kraken的配置是会根据当前NODE_ENV
进行变化,所以如果跑不通的时候最好检查一下当前的NODE_ENV
.默认情况下,NODE_ENV
没有设置或者设置了development
,启动的时候,kraken
会默认加载./public/templates
下的模板,设置了其他值的时候,就会去加载./.build/templates
而这个当你在kraken
项目目录下运行grunt build
就会出现.build
该目录了用于部署在NODE_ENV
设置为production
或者其他值的时候加载.
查看你当前系统的NODE_ENV
环境
Linux or Mac
echo $NODE_ENV
Windows
echo %NODE_ENV%
约定开发
个人看法 kraken
与其说是一个框架好不如说它只不过提供了灵活,方便的用于构建Express应用的方式.
配置(/config)
kraken
在 ./config
约定了两类配置文件:
app.json
用于配置,host, port, i18n ,express 等.middleware
用于对默认中间件的配置,目前支持的中间件有appsec
,compiler
,session
,errorPages
,static
, 详细的参数配置请阅读官方文档,这里就不赘述了.
除此以外,kraken
还约定支持根据NODE_ENV
自动匹配相应的配置文件,规则是:
app-NODE_ENV.json
例如, 当前NODE_ENV
是development
, 你在目录下有一个app-development.json
的文件话,就会优先读取该文件的配置.
控制器(/controllers)
路由控制
kraken
默认会自动加载./controllers
下的文件,进行路由控制,个人觉得,这个真心省心.接下来的写法,与express 完全一样!
module.exports = function (server) {
server.get('/customer', function (req, res) {
res.send('Hello World');
});
};
如果,你是express的开发者,就会越感发现,kraken
更多的是补充了express不足的地方,除此以外跟平常用express开发毫无区别.
自定义中间件 和 周期控制
kraken
将一个请求的周期定义为三级:
app.requestStar
请求开始app.requestBeforeRoute
进行路由前app.requestAfterRoute
路由后输出
整个实现异常简洁, 有兴趣的可以去阅读源码:
appcore.js
line: 172 - 198
定义一个中间件的方法与express的时候一样,只不过,现在多了一步,我们要把中间件放到哪个位置而已
约定在./middleware/lib
下建一个文件,beforeRouteMiddleware.js
module.exports = function () {_
var reqCounts = 0;
return function (req, res, next) {
req.counts = reqCounts | 0;
reqCounts++;
next();
};
};
然后在: index.js
var beforeRouteMiddleware = require('./lib/middleware/beforeRouteMiddleware')
app.requestBeforeRoute = function requestBeforeRoute(server) {
server.use(beforeRouteMiddleware());
};
与express的中间件功能一样,每请求一次,都会触发中间件. 与原生的express不同krarken
提供了更有条例的中间件定义约定.
总结
kraken
还有一些比较实用的功能,例如安全,还有本地化,不过这些内容,官方文档已经写得很详细了,这里就不作过多的说明. 在我看来,kraken
只干了一件事,就是把express条理化了,kraken
并没有对express进行更多的封装,所以,只要会express的入手kraken
就像喝水一样简单. 而kraken
提供的约定,能够更有效率的开发Node.js的web项目.
Kraken.js!的更多相关文章
- Hello Kraken.js!
前言 kraken.js 由paypal 公司开源的一个用于快速开发基于Express.js框架应用的快速开发工具, 因为kraken 并没有在Express.js基础上更改多少东西,只是在原来的 ...
- Node.js 在 PayPal实战
之前有过一个谈了很多关于PayPal移动到node.js的一个应用平台.作为设置我的免费用户界面的第1部分的延续,我很高兴地说,这些传言是真的,我们的Web应用程序正在从Java迁移到JavaScri ...
- PayPal为什么从Java迁移到Node.js
前言 大家都知道PayPal是另一家迁移到Node.js平台的大型公司,Jeff Harrell的这篇博文 Node.js at PayPal 解释了为什么从Java迁移出来的原因: 开发效率提高一 ...
- node.js之十大Web框架
之前接触过Node.js是因为好奇大前端越来越能干了,连我后台的饭碗都要抢了,太嚣张了,于是我想打压打压它,然后就这样接触它了.再到后来是因为Settings-Sync插件二次开发,我需要用node. ...
- [转载]PayPal为什么从Java迁移到Node.js,性能提高一倍,文件代码减少44%
http://ourjs.com/detail/52a914f0127c763203000008 大家都知道PayPal是另一家迁移到Node.js平台的大型公司,Jeff Harrell的这篇博文 ...
- PayPal为什么从Java迁移到Node.js 性能提高一倍 文件代码减少44%
大家都知道PayPal是另一家迁移到Node.js平台的大型公司,Jeff Harrell的这篇博文 Node.js at PayPal 解释了为什么从Java迁移出来的原因: 开发效率提高一倍(2 ...
- ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 用javascript在客户端删除某一个cookie键值对 input点击链接另一个页面,各种操作。 C# 往线程里传参数的方法总结 TCP/IP 协议 用C#+Selenium+ChromeDriver 生成我的咕咚跑步路线地图 (转)值得学习百度开源70+项目
ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 我们都知道在使用WebApi的时候Controller会自动将Action的返回值自动进行各种序列化处理(序列化为 ...
- 带你入门带你飞Ⅱ 使用Mocha + Chai + SuperTest测试Restful API in node.js
目录 1. 简介 2. 准备开始 3. Restful API测试实战 Example 1 - GET Example 2 - Post Example 3 - Put Example 4 - Del ...
- 带你入门带你飞Ⅰ 使用Mocha + Chai + Sinon单元测试Node.js
目录 1. 简介 2. 前提条件 3. Mocha入门 4. Mocha实战 被测代码 Example 1 Example 2 Example 3 5. Troubleshooting 6. 参考文档 ...
随机推荐
- libmsgque官方主页
libmsgque 消息队列(MESSAGE QUEUE)库项目简析 注: 本文如果你已经有linux开发环境 请确保你使用本库时是tag版本号. target=libmsgque-1.0 本项目採用 ...
- Eclipse UML 工具 ObjectAid 介绍
概要 本文介绍如何使用 ObjectAid(http://www.objectaid.com/) UML Explorer 创建 UML 图,高速阅读代码. 安装 ObjectAid ObjectAi ...
- SD3.0四个协议解读
前面的文章提到过SD卡主要分为两个操作模式,一是初始化和识别操作模式.还有一种就是这篇文章须要分析的传输数据模式啦. 传输数据模式: 传输数据模式主要有六种状态,各自是Stand-by状态.Trans ...
- ABP入门教程
ABP入门教程 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称. ASP.NET Boilerplate是一个用最佳实践和流行技术开发现代WEB应 ...
- NFC学习笔记2——Libnfc简介及安装
我一直希望自己的文章做一些记录的英文翻译.趁着学习NFC,现在,libnfc主页libnfc介绍和不同的操作系统libnfc文章做一些翻译安装.一方面,提高自己的英语,一方面有了解libnfc. 原文 ...
- 从头开始学JavaScript (四)——操作符
原文:从头开始学JavaScript (四)--操作符 一.一元操作符 1.自增自减操作符:分为前置型和后置型: 前置型:++a;--a; 后置型:a++;a--; 例: <script typ ...
- axure团队合作开发原型图
谁是人画或其他原型图的头,但在基本制度的发展时,.我们分配一些人画的原型,其他部分干. 再画一个原型不再是一个人画,一起画,假设大家都各自画自己那一部分.最后再由一个人来整合的画.是非常麻烦. 咱平时 ...
- Swift中文教程(一)--欢迎来到Swift的世界
原文:Swift中文教程(一)--欢迎来到Swift的世界 Apple凌晨时在WWDC发布了Swift编程语言,语法简介我很喜欢,市面上没有完整的中文教程,我在ibooks里面下载了英文原版,现在开始 ...
- app后端设计(0)--总文件夹
原文:http://blog.csdn.net/newjueqi/article/details/19003775 做了接近两年app相关的系统架构,api设计,先后在两个创业公司中工作,经历过手机网 ...
- CSS3+HTML5特效2 - 翻转效果
先看效果,鼠标移上去看看. back front 1. 本实例需要以下元素 a. 容器BOX b. 默认显示元素FRONT c. 翻转显示元素BACK 2. 容器BOX的Height为200px,Wi ...