博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
我的第一个Node web程序
阅读量:6619 次
发布时间:2019-06-25

本文共 4234 字,大约阅读时间需要 14 分钟。

NodeJS的流行也带来了开发由前端转到全栈,前端不再局限于页面如何展现,用户如何操作,也设计到整个应用的架构以及业务流程。

本篇来简单的通过实例,讲述node中web开发的模式。

参考来自《Node web开发》一书。

关于node

  node是基于事件的异步驱动系统,通过可扩展的方式创建网络服务器。

  例如,创建一个网络服务器:

var http_port = 8124;var http = require('http');var server = http.createServer(function (req,res){    ....自己的代码});server.listen(http_port);

  这样就可以创建一个简单的服务器。

关于npm

  npm是node的包管理工具,node里面有很多的模块,可以通过require('模块名字')的方式加载到项目中。

  常用的命令:

npm init 创建项目的package.json文件,配置其信息以及依赖项npm install 通过package.json的声明,安装需要的包npm install xxxx 安装xxxx包npm install xxxx --save-dev 以开发模式安装xxxx包,当用于生产环境时,不会下载开发模式的xxxx

关于项目布局

  在node中,很注重模块化,按照commonjs的思想,尽量把功能分散到模块中进行重用。

  但是也有点弊端,会出现很多松散的文件,不易于管理。

  通常node中都会把第三方的模块包,放在node_modules文件夹中,node也会在require()的时候,自动向上搜索该文件家,引用其js。

  node_modules中的js文件,大多是一些加载自动执行的文件,或者对外暴露出一定的接口,比如:

(function(a,b){}(this,function(){//.....}));

  或者

var xxx = require('xxx');exports.funca = function(){//.......xxx}exports.funcb = function(){//.....xxx}

关于代码

  本篇的项目做了一个小网站,通过模块化开发,项目组织如下:

app:|——app-node.js 定义web服务器|——home-node.js 定义home主页模块|——htutil.js 定义工具模块,用于定义导航,以及网页模板替换方法,和获取http信息|——mult-node.js 通过get方法获取参数信息,并执行加法|——package.json 定义网站项目信息

  app-node.js代码:

var http_port = 8124;var http = require('http');var htutil = require('./htutil');var server = http.createServer(function (req,res){    console.log("in server!");    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('./fibonacci-node').get(req,res);    }else if(req.requrl.pathname === '/mult'){        require('./mult-node').get(req,res);    }else{        res.writeHead(404,{'Content-Type':'text/plain'});        res.end("bad url"+req.url);    }});server.listen(http_port);console.log('listening to http://localhost:8124');

  home-node.js

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

Math Wizard

" ));}

  mult-node.js

var htutil = require("./htutil");exports.get = function(req,res){    res.writeHead(200,{        'Content-Type':'text/html'    });    var result = req.a * req.b;    res.end(        htutil.page("Multiplication",htutil.navbar(),[                (!isNaN(req.a) && !isNaN(req.b)                    ?(                        "

{a}*{b}={result}

" .replace("{a}",req.a) .replace("{b}",req.b) .replace("{result}",req.a*req.b) ) :""), "

Enter numbers to multiply

", "
", "A:
", "B:
", "
" ].join('\n')) );}

  htutil.js

var url = require('url');//get url params a & bexports.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 ["
" ].join('\n');}//exports.page = function(title,navbar,content){ return ["{title}", "{navbar}{content}", "" ].join('\n') .replace("{title}",title,"g") .replace("{navbar}",navbar,"g") .replace("{content}",content,"g");}

  package.js

{  "name": "chap04",  "version": "1.0.0",  "description": "",  "main": "app-node.js",  "scripts": {    "test": "echo \"Error: no test specified\" && exit 1"  },  "author": "",  "license": "ISC"}

  执行命令行:

node app-node.js

  访问http://localhost:8124,就可以访问到网址:

本文转自博客园xingoo的博客,原文链接:,如需转载请自行联系原博主。
你可能感兴趣的文章
添加 All Exceptions 断点后, 每次运行都会在 main.m 中断的一种解决方法
查看>>
ROC曲线(receiver-operating-characteristic curve)-阈值评价标准(转)
查看>>
Swift 表达式
查看>>
FFmpeg(8)-打开音视频解码器,配置解码器上下文(avcodec_find_decoder()、avcodec_alloc_context3())...
查看>>
andriod自定义视图
查看>>
linux下vim更改注释颜色
查看>>
在SSL / https下托管SignalR
查看>>
Using JRuby with Maven
查看>>
poj 3308 (最大流)
查看>>
Netty了解与小试
查看>>
醒醒吧少年,只用Cucumber不能帮助你BDD
查看>>
一名女程序员对iOS的想法
查看>>
Cloud Native未来值得关注的方向:Service Mesh简介
查看>>
西班牙现新型电费退款网络诈骗 侨胞需谨防上当
查看>>
JVM新生代和老年代配置原则
查看>>
太合音乐发布“少年红星音乐计划” 力促00后创作浪潮
查看>>
ICO后STO也被明令禁止,区块链并不是法外之地
查看>>
浅尝辄止,React是如何工作的
查看>>
6000多套iOS源码大分享
查看>>
一个完整Java Web项目背后的密码
查看>>