app-node.js

var http_port = ;

var http = require('http');
var htutil = require('./htutil'); var server = http.createServer(function(req, res){
htutil.loadParams(req, res, undefined);
if (req.requrl.pathname === '/'){
require('./home-node').get(req, res);
}else if (req.requrl.pathname === '/square'){
require('./square-node').get(req, res);
}else if (req.requrl.pathname === '/factorial'){
require('./factorial-node').get(req, res);
}else if (req.requrl.pathname === '/fibonacci'){
require('./fibo-node').get(req, res);
}else if (req.requrl.pathname === '/mult'){
require('./mult-node').get(req, res);
}else{
res.writeHead(, {'Content-Type': 'text/plain'});
res.end("bad URL" + req.url);
}
}); server.listen(http_port);
console.log('listening to http://localhost:3000');

htutil.js

var url = require('url');
exports.loadParams = function(req, res, next){
req.requrl = url.parse(req.url, true);
req.a = (req.requrl.query.a && !isNaN(req.requrl.query.a))
? new Number(req.requrl.query.a)
: NaN;
req.b = (req.requrl.query.b && !isNaN(req.requrl.query.b))
? new Number(req.requrl.query.b)
: NaN;
if(next) next();
} exports.navbar = function(){
return ["<div class='navbar'>",
"<p><a href='/'>home</a></p>",
"<p><a href='/mult'>Multiplication</a></p>",
"<p><a href='/square'>Square</a></p>",
"<p><a href='/factorial'>Factorial</a></p>",
"<p><a href='/fibonacci'>Fibonacci</a></p>",
"</div>"].join('\n');
} exports.page = function(title, navbar, content){
return ["<html><head><title>{title}</title></head>",
"<body><h1>{title}</h1>",
"<table><tr>",
"<td>{navbar}</td><td>{content}</td>",
"</tr></table></body></html>"
].join('\n')
.replace(new RegExp("{title}", "gm"), title)
.replace("{navbar}", navbar)
.replace("{content}", content);
}

home-node.js

var htutil = require('./htutil');

exports.get = function(req, res){
res.writeHead(, {'Content-Type': 'text/html'});
res.end(htutil.page("Math Wizard", htutil.navbar(), "<p>Math Wizard</p>"));
}

square-node.js

var htutil = require('./htutil');
exports.get = function(req, res){
res.writeHead(, {'Content-Type': 'text/html'});
var result = req.a * req.a;
res.end(
htutil.page("Square", htutil.navbar(), [
(!isNaN(req.a) ?
("<p class='result'>{a} squared = {sq}</p>"
.replace("{a}", req.a)
.replace("{sq}", req.a * req.a))
: ""),
"<p>Enter numbers to see its square</p>",
"<form name='square' action='/square' method='get'>",
"A: <input type='text' name='a' /><br/>",
"<input type='submit' value='Submit' />",
"</form>"
].join('\n'))
);
}

factorial-node.js

var htutil = require('./htutil');
var math = require('./math'); exports.get = function(req, res){
res.writeHead(, {'Content-Type': 'text/html'});
res.end(
htutil.page("Factorial", htutil.navbar(), [
(!isNaN(req.a) ?
("<p class='result'>{a} factorial = {fact}</p>"
.replace("{a}", req.a)
.replace("{fact}", math.factorial(Math.floor(req.a))))
: ""),
"<p>Enter numbers to see its factorial</p>",
"<form name='factorial' action='/factorial' method='get'>",
"A: <input type='text' name='a' /><br/>",
"<input type='submit' value='Submit' />",
"</form>"
].join('\n'))
);
}

mult-node.js

var htutil = require('./htutil');
exports.get = function(req, res){
res.writeHead(, {'Content-Type': 'text/html'});
var result = req.a * req.b;
res.end(
htutil.page("Multiplication", htutil.navbar(), [
(!isNaN(req.a) && !isNaN(req.b) ?
("<p class='result'>{a} * {b} = {result}</p>"
.replace("{a}", req.a)
.replace("{b}", req.b)
.replace("{result}", req.a * req.b))
: ""),
"<p>Enter numbers to mutiply</p>",
"<form name='mult' action='/mult' method='get'>",
"A: <input type='text' name='a' /><br/>",
"B: <input type='text' name='b' /><br/>",
"<input type='submit' value='Submit' />",
"</form>"
].join('\n'))
);
}

fibo-node.js

var htutil = require('./htutil');
var math = require('./math'); exports.get = function(req, res){
res.writeHead(, {'Content-Type': 'text/html'});
res.end(
htutil.page("Fibonacci", htutil.navbar(), [
(!isNaN(req.a) ?
("<p class='result'>{a} fibonacci = {fibo}</p>"
.replace("{a}", Math.floor(req.a))
.replace("{fibo}", math.fibonacci(Math.floor(req.a))))
: ""),
"<p>Enter numbers to see its fibonacci</p>",
"<form name='fibonacci' action='/fibonacci' method='get'>",
"A: <input type='text' name='a' /><br/>",
"<input type='submit' value='Submit' />",
"</form>"
].join('\n'))
);
}

fibo2-node.js

var htutil = require('./htutil');
var math = require('./math'); function sendResult(req, res, a, fiboval){
res.writeHead(, {'Content-Type': 'text/html'});
res.end(
htutil.page("Fibonacci", htutil.navbar(), [
(!isNaN(fiboval) ?
("<p class='result'>{a} fibonacci = {fibo}</p>"
.replace("{a}", a)
.replace("{fibo}", fiboval))
: ""),
"<p>Enter numbers to see its fibonacci</p>",
"<form name='fibonacci' action='/fibonacci' method='get'>",
"A: <input type='text' name='a' /><br/>",
"<input type='submit' value='Submit' />",
"</form>"
].join('\n'))
);
} exports.get = function(req, res){
if (!isNaN(req.a)){
math.fibonacciAsync(Math.floor(req.a), function(val){
sendResult(req, res, Math.floor(req.a) ,val);
});
}else {
sendResult(req, res, NaN, NaN);
}
}

math.js

var factorial = exports.factorial = function(n){
if (n == )
return ;
else
return n * factorial(n-);
} var fibonacci = exports.fibonacci = function(n){
if (n === )
return ;
else if (n === )
return ;
else
return fibonacci(n-) + fibonacci(n-);
} var fibonacciAsync = exports.fibonacciAsync = function(n, done){
if (n == || n == )
done();
else {
process.nextTick(function(){
fibonacciAsync(n-, function(val1){
process.nextTick(function(){
fibonacciAsync(n-, function(val2){
done(val1 + val2);
});
})
});
});
}
}

  

从零开始学习Node.js例子四 多页面实现数学运算的更多相关文章

  1. 从零开始学习Node.js例子四 多页面实现数学运算 续二(client端和server端)

    1.server端 支持数学运算的服务器,服务器的返回结果用json对象表示. math-server.js //通过监听3000端口使其作为Math Wizard的后台程序 var math = r ...

  2. 从零开始学习Node.js例子四 多页面实现数学运算 续一(使用connect和express框架)

    1.使用connect框架 .use方法用于绑定中间件到connect服务器,它会配置一系列在接到请求时调用的中间件模块,此例中我们要配置的中间件有favicon logger static rout ...

  3. 从零开始学习Node.js例子三 图片上传和显示

    index.js var server = require("./server"); var router = require("./router"); var ...

  4. 从零开始学习Node.js例子一 http get和post

    httpserverrequestget.js /* 获取GET请求内容 由于GET请求直接被嵌入在路径中,URL是完整的请求路径,包括了?后面的部分,因此你可以手动解析后面的内容作为GET请求的参数 ...

  5. 从零开始学习Node.js例子八 使用SQLite3和MongoDB

    setup.js:初始化数据库 var util = require('util'); var async = require('async'); //npm install async var no ...

  6. 从零开始学习Node.js例子七 发送HTTP客户端请求并显示响应结果

    wget.js:发送HTTP客户端请求并显示响应的各种结果 options对象描述了将要发出的请求.data事件在数据到达时被触发,error事件在发生错误时被触发.HTTP请求中的数据格式通过MIM ...

  7. 从零开始学习Node.js例子六 EventEmitter发送和接收事件

    pulser.js /* EventEmitter发送和接收事件 HTTPServer和HTTPClient类,它们都继承自EventEmitter EventEmitter被定义在Node的事件(e ...

  8. 从零开始学习Node.js例子九 设置HTTP头

    server.js //basic server的配置文件 ; var server = require('./basicserver').createServer(); server.useFavI ...

  9. 从零开始学习Node.js例子五 服务器监听

    httpsnifferInvoke.js var http = require('http'); var sniffer = require('./httpsniffer'); var server ...

随机推荐

  1. C语言:内存字节对齐详解[转载]

    一.什么是对齐,以及为什么要对齐: 1. 现代计算机中内存空间都是按照byte划分的,从理论上讲似乎对任何类型的变量的访问可以从任何地址开始,但实际情况是在访问特定变量的时候经常在特定的内存地址访问, ...

  2. 我的android学习经历37

    android虚拟机没有键盘的问题,那是因为建立虚拟机的时候没有选择skin,重新编辑选择skin就可以了

  3. Linux文本流

    Linux文本流   作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 文本流 文件用于数据的存储,相当于一个个存储数据的房子.我们 ...

  4. React的Transaction浅析

    1.两个示例 示例1 let SonClass = React.createClass({ render: function(){ console.log("render", th ...

  5. PHP文本框的值随下拉框改变

    初学PHP,下面是实现文本框内容随下拉框变化的代码实现: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...

  6. iOS MD5加密字符串

    参考:http://stackoverflow.com/questions/1524604/md5-algorithm-in-objective-c 在线测试MD5:http://www.cmd5.c ...

  7. CSRF攻击原理以及防御

    一.CSRF是什么? CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click attack/session riding,缩写为:CSR ...

  8. Python中的logging模块

    http://python.jobbole.com/86887/ 最近修改了项目里的logging相关功能,用到了python标准库里的logging模块,在此做一些记录.主要是从官方文档和stack ...

  9. [SoapUI] SoapUI Response 格式控制

    application/后面可以修改为自己所需要的内容格式.

  10. 改善过多的if else

    刚看到一个提问帖: <如果程序中出现多层嵌套的 if...else...语句,如何重构可使程序逻辑变得更为清晰易读?>,因回答篇幅比较大,单独开个帖子答一下. 个人喜好代码风格不一样,下面 ...