从零开始学习Node.js例子四 多页面实现数学运算
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例子四 多页面实现数学运算的更多相关文章
- 从零开始学习Node.js例子四 多页面实现数学运算 续二(client端和server端)
1.server端 支持数学运算的服务器,服务器的返回结果用json对象表示. math-server.js //通过监听3000端口使其作为Math Wizard的后台程序 var math = r ...
- 从零开始学习Node.js例子四 多页面实现数学运算 续一(使用connect和express框架)
1.使用connect框架 .use方法用于绑定中间件到connect服务器,它会配置一系列在接到请求时调用的中间件模块,此例中我们要配置的中间件有favicon logger static rout ...
- 从零开始学习Node.js例子三 图片上传和显示
index.js var server = require("./server"); var router = require("./router"); var ...
- 从零开始学习Node.js例子一 http get和post
httpserverrequestget.js /* 获取GET请求内容 由于GET请求直接被嵌入在路径中,URL是完整的请求路径,包括了?后面的部分,因此你可以手动解析后面的内容作为GET请求的参数 ...
- 从零开始学习Node.js例子八 使用SQLite3和MongoDB
setup.js:初始化数据库 var util = require('util'); var async = require('async'); //npm install async var no ...
- 从零开始学习Node.js例子七 发送HTTP客户端请求并显示响应结果
wget.js:发送HTTP客户端请求并显示响应的各种结果 options对象描述了将要发出的请求.data事件在数据到达时被触发,error事件在发生错误时被触发.HTTP请求中的数据格式通过MIM ...
- 从零开始学习Node.js例子六 EventEmitter发送和接收事件
pulser.js /* EventEmitter发送和接收事件 HTTPServer和HTTPClient类,它们都继承自EventEmitter EventEmitter被定义在Node的事件(e ...
- 从零开始学习Node.js例子九 设置HTTP头
server.js //basic server的配置文件 ; var server = require('./basicserver').createServer(); server.useFavI ...
- 从零开始学习Node.js例子五 服务器监听
httpsnifferInvoke.js var http = require('http'); var sniffer = require('./httpsniffer'); var server ...
随机推荐
- JS设置cookie
cookie 与 session 是网页开发中常用的信息存储方式.Cookie是在客户端开辟的一块可存储用户信息的地方:Session是在服务器内存中开辟的一块存储用户信息的地方. JavaScrip ...
- laravel框架总结(四) -- 服务容器
1.依赖 我们定义两个类:class Supperman 和 class Power,现在我们要使用Supperman ,而Supperman 依赖了Power class Supperman { p ...
- canvas 绘图
<canvas>元素是HTML5中的绘图元素,通过定义一个画布区域,然后使用javascript动态地在这个区域里面绘制图形,对于2D和3D图形都可以绘制,我们将其分成2D上下文和WebG ...
- CentOS 7下关于systemd的一些唠叨话一:systemd的特点和使用
摘要 近年来,Linux 系统的 init 进程经历了两次重大的演进,传统的 sysvinit 已经逐渐淡出历史舞台,新的 UpStart 和 systemd 各有特点,越来越多的 Linux 发行版 ...
- signtool
https://msdn.microsoft.com/en-us/library/8s9b9yaz(v=vs.110).aspx C:\Users\Administrator\.nuget\packa ...
- 在代码中调用gdb
转载:http://blog.csdn.net/hanchaoman/article/details/5583457 在SIGSEGV的handler中调用gdb, 命令gdb [exec file] ...
- WPF-非矩形窗口的创建
第一.窗口的AllowsTransparency设置为True 第二.窗口的Background设置为Transparent 第三.窗口的WindowStyle设置为None 第四.窗口内的Grid用 ...
- 《BI那点儿事》数据流转换——百分比抽样、行抽样
百分比抽样和行抽样可以从数据源中随机选择一组数据.这两种task都可以产生两组输出,一组是随机选择的,另一组是没有被选择的.可以将这些选择出的数据发送到开发或者测试服务器上.这个Task的最合适的应用 ...
- LTE Module User Documentation(翻译13)——频率复用算法(Frequency Reuse Algorithms)
LTE用户文档 (如有不当的地方,欢迎指正!) 19 Frequency Reuse Algorithms(频率复用算法) 本节我们将描述如何在 LTE 仿真中使用频率复用(FR)算法.共有两 ...
- [Oracle] SQL*Loader 详细使用教程(1)- 总览
SQL*Loader原理 SQL*Loader是Oracle提供的用于数据加载的一种工具,它比较适合业务分析类型数据库(数据仓库),能处理多种格式的平面文件,批量数据装载比传统的数据插入效率更高. ...