Codekart 框架
[Node.js框架] 为什么要开发 Codekart 框架
两年前,在被php的$符号和字符串处理折磨得半夜骂娘之后,我义无反顾地决定:珍爱生命,远离php。
之后一直在寻找一门“完美的语言”,先后接触了Lisp、python、java、Ruby。Lisp几乎在语法和思想上达到了完美,但却由于过于小众和开发环境的不完善,导致基本找不到工作,也只能作为业余时间的写一些有趣的东西了。python的强制缩进,说实话相当于告诉程序员:嘿,你个SB!到底会不会排版?我一直坚定的认为,充分相信程序员给于程序员最大的自由,而不是害怕程序员犯错误替程序员做出决定的语言更加Geek,难道不是么?java的语法像老奶奶的裹脚布,又臭又长,各种库臃肿庞大,我可不想到哪儿都背着一个沉重的工具箱,我希望的是一把瑞士军刀,或者一件能制作工具的工具。Ruby各方面比较平衡,看起来还比较适合。
就在我做好准备投入Ruby的怀抱时,由于项目需要写了一些javascript代码,才对这个一直被我忽略的语言有了充分的认识和了解。如果说写js有什么体会,那就是“自由”!你只需要专注于功能本身的实现,不用花大量时间和精力去跟语言本身的特征打交道。举个反例,我的入门语言是C++,当时做MFC开发的感觉就是自己简直是一个弱智,巨大的挫折感每天都在打垮自己的意志,因为大量的时间被耗费在了解和突破语言的限制、担心内存泄露和程序出错上面,战战兢兢如履薄冰,甚至半夜惊醒。后来写js之后发现,之前在c++里写的大量代码,居然是在实现另一们语言本身的“高级”特征!
当Node.js带着精简优雅的设计和优越的性能扑面而来时,我感觉自己像坠入了爱河。关于Node.js的优缺点,可以看我在君鉴上的文章专辑:Node.js技术研究。在这个文章大大地将node夸赞了一番,极尽谄媚马屁之能事。
接下来就是长时间高强度的了解Node.js了。在基本阅读了手册之后,我开始写了一些代码,比如按照教程写了静态文件服务器,和websocket聊天程序。之后开始寻找一个开发框架,当然第一个映入眼帘的就是大名鼎鼎的Express。简单尝试之后,惊叹于Express的url路由真的十分强大!但是也学是因为自己长时间习惯于php开发,总觉得Express“不像”是一个框架,因为Express还需要自己组织程序的模块化,需要自己进行视图和处理程序的分离,等等。
于是,我决定不借助任何框架从零开始重写君鉴,并在重写的过程中开发一个MVC模式的框架。我认为这是一个大工程,将要耗费我大量的时间。
事实上,得益于语言本身的“高级”,重写并没有花掉我太多的时间。一路畅快的完成开发后,一个粗略的框架基本完成了。由于之前写php时一直使用codeigniter,我把这个新开发的框架命名为 Codekart ,kart的意思是卡丁车,Codekart 是小巧精简、高性能、功能完善的框架,使用Codekart开发web程序就像驾驶卡丁车一样畅快而且“好玩儿”。Codekart已经帮你出色的完成了下面的工作:
- 高性能 MVC 开发框架
- 具备客户端缓存支持的静态文件服务器
- view页面、binary二进制文件处理、api请求等 url 路由
- view页面继承支持、配置生成化及模板数据解析
- js、css、html 的模块化按需加载,并合并压缩
- Tool常用工具箱,例如模板解析和流程控制工具等等
- 精简而强大的前端 js 常用方法库
框架的设计思想和目录结构一部分借鉴了codeigniter,将app与framework分开,在此基础上再将静态所有静态文件归类到static目录,大致如下:
|
1
2
3
4
5
6
7
|
│├─ app ┐ //工程文件目录,程序开发工作在此进行│├─ framework ┐ //框架文件目录│├─ static ┐ //静态文件目录│ |
详细文件夹结构,在这里:Codekart目录结构。
由于篇幅所限,这里不能一一介绍。下面就选取框架比较突出的功能:web页面模块化配置。
例如: framework/view/html.js 内容如下:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
//web页面顶级页面定义exports.stuff = { tpl:{html:'html'}, //页面的tpl模板文件列表 tpl_pre:[], //待用的tpl文件列表 会被加入js文件里面待用 保存在app/view/tpl文件夹 格式{note_list:'abc/abc'} less:'html', //页面的css模板文件列表 csslib:[], //css库文件,在static/csslib目录下 js:[ 'functions', 'json', 'cookie', 'jq-extend', 'tmpl', 'pro' ], //页面的js模板文件列表 jslib: 'jquery-2.0.3.min' //js库文件列表,在static/jslib目录下};var website = require_config('website');/** * tpl模板数据获取函数 * @param callback 返回模板数据 */exports.data = function(callback){ var that = this , req = this.request; //原生的request请求对象 callback({ title: website.name, time: req.time, website: website },{ website: website });}; |
exports.stuff 对象及为web页面的配置,exports.data函数为页面模板数据的获取函数。你也可以方便的进行页面的继承。更多内容可以访问 Codekart文档手册。
目前为止,Node.js仍然是一个年轻的但却充满活力的服务器解决方案。国内的使用者包括阿里巴巴、一些大数据处理和一些游戏公司使用,但它的适用环境却远不止做游戏后端和大数据接口。用Node可以让网站更加“实时”,性能更加突出,可以处理海量的数据请求,Codekart的开发初衷是为了在享受高性能的同时,让网站开发更加快速和便捷。
你可以在如下地方下载或了解Codekart:
Github: https://github.com/myworld4059/Codekart
主页: http://codekart.jojoin.com/
使用手册: http://docs.codekart.jojoin.com
欢迎提出建议或者BUG反馈!
Codekart 框架的更多相关文章
- [Node.js框架] 为什么要开发 Codekart 框架
两年前,在被php的$符号和字符串处理折磨得半夜骂娘之后,我义无反顾地决定:珍爱生命,远离php. 之后一直在寻找一门“完美的语言”,先后接触了Lisp.python.java.Ruby.Lisp几乎 ...
- 避免重复造轮子的UI自动化测试框架开发
一懒起来就好久没更新文章了,其实懒也还是因为忙,今年上半年的加班赶上了去年一年的加班,加班不息啊,好了吐槽完就写写一直打算继续的自动化开发 目前各种UI测试框架层出不穷,但是万变不离其宗,驱动PC浏览 ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
- 旺财速啃H5框架之Bootstrap(五)
在上一篇<<旺财速啃H5框架之Bootstrap(四)>>做了基本的框架,<<旺财速啃H5框架之Bootstrap(二)>>篇里也大体认识了bootst ...
- Angular企业级开发(5)-项目框架搭建
1.AngularJS Seed项目目录结构 AngularJS官方网站提供了一个angular-phonecat项目,另外一个就是Angular-Seed项目.所以大多数团队会基于Angular-S ...
- Scrapy框架爬虫初探——中关村在线手机参数数据爬取
关于Scrapy如何安装部署的文章已经相当多了,但是网上实战的例子还不是很多,近来正好在学习该爬虫框架,就简单写了个Spider Demo来实践.作为硬件数码控,我选择了经常光顾的中关村在线的手机页面 ...
- 制作类似ThinkPHP框架中的PATHINFO模式功能
一.PATHINFO功能简述 搞PHP的都知道ThinkPHP是一个免费开源的轻量级PHP框架,虽说轻量但它的功能却很强大.这也是我接触学习的第一个框架.TP框架中的URL默认模式即是PathInfo ...
- 旺财速啃H5框架之Bootstrap(四)
上一篇<<旺财速啃H5框架之Bootstrap(三)>>已经把导航做了,接下来搭建内容框架.... 对于不规整的网页,要做成自适应就有点玩大了.... 例如下面这种版式的页面. ...
- 一起学 Java(三) 集合框架、数据结构、泛型
一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...
随机推荐
- 记得12306货运系统“抢购空”编写插件--chrome交互式插件的各个部分
--chrome交互式插件的各个部分 Chrome插件的基础知识就不多说了.随便找个新手教程就能够上手了,比如官方提供的Overview与Getting Started教程足够入门了:笔者也是现学现卖 ...
- JavaScript之对象序列化详解
一.什么是对象序列化? 对象序列化是指将对象的状态转换为字符串(来自我这菜鸟的理解,好像有些书上也是这么说的,浅显易懂!): 序列化(Serialization)是将对象的状态信息转换为可以存储或传输 ...
- HDU 2841 Visible Trees(数论)
标题效果:给你个m*n方格,广场格从(1,1)开始. 在树中的每个点,然后让你(0,0)点往下看,问:你能看到几棵树. 解题思路:假设你的视线被后面的树和挡住的话以后在这条线上的树你是都看不见的啊.挡 ...
- HTML DOM的nodeName,nodeValue,nodeType介绍
将HTML DOM中几个常用的属性做下介绍,工作中作为参考. nodeName 属性可依据节点的类型返回其名称. 元素节点的 nodeName 是标签名称 属性节点的 nodeName 是属性名称 文 ...
- 3.集--LinkedTransferQueue得知
近期在阅读开源项目里,发现有几个project都不尽同样地使用LinkedTransferQueue这个数据结构.比方netty,grizzly,xmemcache,Bonecp. Bonecp还扩展 ...
- 房间计费系统改造E-R图纸设计
简单的学习过程: 这几天忙得太混乱了,用了近一个星期才设计好.我在这段时间遇到的困难,就积极找师哥师姐指点迷津,如今多少总算是有些拿得出手的成果. 学习成果: Entity Relations ...
- 【高德API】如何利用MapKit开发全英文检索的iOS地图
原文:[高德API]如何利用MapKit开发全英文检索的iOS地图 制作全英文地图的展示并不困难,但是要制作全英文的数据检索列表,全英文的信息窗口,你就没办法了吧.告诉你,我有妙招!使用iOS自带的M ...
- Swift语言指南(六)--可选值
原文:Swift语言指南(六)--可选值 在值可能不存在的情况下使用可选值(optional), 可选值是: · 存在一个值,这个值等于 x 或 · 不存在任何值 注: 在 C 和 Objective ...
- EasyUi TreeGrid封装
礼物一:树型实体的抽象与封装 所谓树型实体,就是具有树型结构关系的实体,比如省.市.区.对于初学者,可能会创建三张表进行存储,有经验的开发者通过引入ParentId将设计简化为一张表,但是基于Pare ...
- php 常用 小知识点
PHP 邮箱正则表达式代码如下: /^([a-z0-9])(([-a-z0-9._])*([a-z0-9]))*\@([a-z0-9])*(\.([a-z0-9])([-a-z0-9_-])([a-z ...