日期:2014-05-16 浏览次数:20376 次
我也来学习nodejs 郁闷的天 文档很不咋的 实例根本跟不上 产品不成熟
?
完事开头难,聊天室还是有困难的啊 写起来 今天下午第一次接触这个玩意 ...
?
忽然发现 完全与之前的web开发 不挂钩 后端 还得自己去 处理各种请求 ....
?
实现聊天室 如果没有一个标准的话 后面东西很乱.... 写就写好 ...
?
先把框架雏形写出来再说 ... 靠 我也实现个MVC出来玩
?
下面这个雏形 基本源自 我自己的php框架思想 .... 基本有了 明天继续实现
?
今明2天把 框架实现好,后面可以自己叠加应用了 .......
?
可能哥以后 就有段时间折腾这破玩意了...
?
?
?
console.log('kenxu聊天室程序'); // 实现 简易的MVC模式 var Http = require('http'); var System = require("sys"); var FileSystem = require("fs"); var Url = require("url"); // 工具代码 var __undef = 'undefined',__proto = "prototype"; Object.extend = function(dest, source) { for (var property in source) dest[property] = source[property]; return dest; }; Object.extend(String[__proto],{ trim: function(){return this.replace(/^\s+|\s+$/g, '');} }); var Utilities = { arrayMap: function(list, fn) { if (list && list.length){ var r = []; for (var i = 0; i < list.length; i++) { var x = fn(list[i], i); if (x !== null) { r.push(x) ; } } return r ; } return []; } , each: function(list,fn){ if (list && list.length) for (var i = 0; i < list.length; i++) if (fn.call(list[i],i) == '#end#') break ; } }; /** * UDI 对象 实现请求资源定位器 * @type */ var UDI = { UDI_CONTROLLER: 'controller', UDI_ACTION: 'action', DEFAULT_CONTROLLER: 'application', DEFAULT_ACTION: 'index' }; function __request_filter(pathinfo){ var pathinfo = pathinfo || '/'; var parts = pathinfo.substr(1).split('/'); var params = {}; if (parts[0] && parts[0].trim().length > 0){ params[UDI.UDI_CONTROLLER] = parts[0].trim(); } if (parts[1] && parts[1].trim().length > 0){ params[UDI.UDI_ACTION] = parts[1].trim(); } for (var i = 2; i < parts.length; i += 2) { if (parts[i + 1]) { params[parts[i]] = parts[i + 1]; } } // 校验 UDI参数是否存在 if (!params[UDI.UDI_CONTROLLER]){ params[UDI.UDI_CONTROLLER] = UDI.DEFAULT_CONTROLLER; } if (!params[UDI.UDI_ACTION]){ params[UDI.UDI_ACTION] = UDI.DEFAULT_ACTION; } return params; } var QRequest = function(req){ this._req = req; }; /** * 单一入口分发器 * @type */ var Dispatcher = { /** * 请求分发方法,可能会抛出异常,不知道异常怎么写... * * @param {} request * @param {} response */ dispose: function(request, response){ // 取拼装控制器以及action var pathinfo = Url.parse(request.url).pathname; var params = __request_filter(pathinfo); console.log(params); response.writeHead(200, {'Content-Type': 'text/plain'}); response.end(pathinfo + '\n'); } }; //SFW.Controller = function(request) Http.createServer(function (request, response) { try { Dispatcher.dispose(request, response); } catch(e){ console.log(e); } }).listen(8124);
?
运行之后
?
http://localhost:8124/ 会输出 { controller: 'application', action: 'index' }
?
http://localhost:8124/hello/world/id/123/page/12 会输出
{ controller: 'hello',
? action: 'world',
? id: '123',
? page: '12' }
?
似乎 还行啊 不知道性能怎么样....
?
下面把 网站贴下 方便 学习:
?
?
https://github.com/joyent/node/wiki/modules
http://cnodejs.org/blog/?p=104
http://www.cnblogs.com/QLeelulu/archive/2011/01/28/nodejs_into_and_n2mvc.html? 源代码下载
http://cnodejs.org/cman/ []
http://cnodejs.org/api/
http://seajs.com/
http://www.w3school.com.cn/js/jsref_substr.asp
?