node.js中允许的app对象声明方式
- 伪对象形式
app = function () {
console.log("我是一个初始化的app对象");
};
app.get=function () {
console.log('这是一个app的get方法');
};
app.post = function () {
console.log('这是一个post方法');
};
app();
app.post();
输出结果
我是一个初始化的app对象
这是一个post方法
- 一个增强的伪对象
G={};
var app = function (req,res) {
if (G['login'])
{
G['login'](req,res);
}
};
app.get=function (urlinstring,callback) {
G[urlinstring]=callback;
};
app.get('login',function (req,res) {
//注意,这里的req和res并非http server中的请求和相应对应的req和res
console.log("这是login方法用到的参数req的值:"+req);
console.log('this is a module for login');
});
setTimeout(function (){
app("嘿~人参娃哟~,嘿真机灵","人参王国片头曲");
},);
输出结果:
这是login方法用到的参数req的值:嘿~人参娃哟~,嘿真机灵
this is a module for login
- 进化版本(新建一个文件夹logic,新起一个文件myserver.js,根据需要,总之新文件一定要有)
var http =require('http');
var app = require('./logic/apphandler');
http.createServer(app).listen();//一旦app对象作为http createServer方法的参数req和res就分别代表http的请求和响应
- 再起一个文件(apphandler.js)
G={};
var url= require('url');
var app = function (req,res) {
var urlobj = url.parse(req.url);
var pathname = urlobj.pathname;
res.writeHead(,{'Content-Type':'text/html;charset=UTF-8'});
console.log("pathname: "+pathname);
if (G[pathname])
{
G[pathname](req,res);
}
else
{
G['/'](req,res);
}
};
app.get=function (urlinstring,callback) {
G[urlinstring]=callback;
};
app.get('/login',function (req,res) {
res.write("这是login方法用到的参数req的值:"+req);
res.end('this is a module for login');
});
app.get('/',function (req,res) {
var pathname=url.parse(req.url).pathname;
res.end("这是首页");
//console.log('this is a module for login');
});
/*
setTimeout(function (){
app("嘿~人参娃哟~,嘿真机灵","人参王国片头曲");
},3000);*/
module.exports=app;
输出结果:


node.js中允许的app对象声明方式的更多相关文章
- JS中遍历数组、对象的方式
1.标准的for循环遍历数组 //不打印自定义属性和继承属性 var array = [1,2,3]; for (var i = 0; i < array.length; i++) { cons ...
- 如何在Node.js中合并两个复杂对象
通常情况下,在Node.js中我们可以通过underscore的extend或者lodash的merge来合并两个对象,但是对于像下面这种复杂的对象,要如何来应对呢? 例如我有以下两个object: ...
- Node.js中的Session,不要觉得简单哦。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,博客地址为http://www.cnblogs.com/jasonnode/ .学习网站上有对应 ...
- node.js中express模块创建服务器和http模块客户端发请求
首先下载express模块,命令行输入 npm install express 1.node.js中express模块创建服务端 在js代码同文件位置新建一个文件夹(www_root),里面存放网页文 ...
- Node.js中环境变量process.env详解
Node.js中环境变量process.env详解process | Node.js API 文档http://nodejs.cn/api/process.html官方解释:process 对象是一个 ...
- 在Node.js中操作文件系统(一)
在Node.js中操作文件系统 在Node.js中,使用fs模块来实现所有有关文件及目录的创建,写入及删除操作.在fs模块中,所有对文件及目录的操作都可以使用同步与异步这两种方法.比如在执行读文件操作 ...
- 深入理解Node.js中的垃圾回收和内存泄漏的捕获
深入理解Node.js中的垃圾回收和内存泄漏的捕获 文章来自:http://wwsun.github.io/posts/understanding-nodejs-gc.html Jan 5, 2016 ...
- node.js中的url.parse方法使用说明
node.js中的url.parse方法使用说明:https://blog.csdn.net/swimming_in_it_/article/details/77439975 版权声明:本文为博主原创 ...
- node.js中模块和包
node.js中模块和包 什么是模块 如何创建并加载模块 1. 创建模块 2. 单次加载 3. 覆盖 exports 如何创建一个包 1. 作为文件夹的模块 2. package.json 如何使用包 ...
随机推荐
- hdoj2594(kmp算法next数组的应用)
题目链接:https://vjudge.net/problem/HDU-2594 题意:给定两个字符串s1.s2,求s1的前缀和s2的后缀的最长公共部分. 思路: 将s1和s2连接后求nex数组即可, ...
- ubuntu18和windows10双系统时间不同步问题(Ubuntu)
1.安装并校准时间 sudo apt install ntpdate sudo ntpdate time.windows.com 2.写入硬件配置 sudo hwclock --localtime - ...
- 基于AbstractRoutingDataSource实现动态切换数据源
基于AbstractRoutingDataSource实现动态切换数据源 /** * DataSource注解接口 */ @Target({ElementType.TYPE, ElementTyp ...
- (九)Javabean与Jsp(来自那些年的笔记)
目录 JavaBean 在JSP中使用JavaBean 标签用法 带标签体的 JavaBean 标签 setProperty 标签 getProperty 标签 JSP开发模式 案列:使用 模式一 编 ...
- 汉字在unicode中的位置
在www.unicode.org中查找汉字.china找不到,后来查资料才明白,应该查CJK,为什么内? unicode这个组织吧中国日本韩国的字合并了 中日韩统一表意文字(CJK Unified ...
- 最全APP安装/卸载/更新测试点
1.安装查看在安装过程中存在的提示信息是否明确,意思是否明确在安装过程中,点击取消按钮,能否正常退出安装程序,软件是否可用.安装时是否识别有SD卡,并默认安装到sd卡中安装过程中,接听电话或者短信,安 ...
- jenkins 安装插件失败
大家在使用jenkins安装插件的时候经常遇到一下问题,就是插件由于网络或者墙的原因无法直接下载,出现下面截图的问题,处理办法有两种 第一种:更换源的问题jenkins->系统管理->管理 ...
- Thymeleaf 模板使用 Error resolving template "/home", template might not exist or might not be accessible by any of the
和属性文件中thymeleaf模板的配置相关 1.配置信息 spring.thymeleaf.prefix=classpath:/templates/ spring.thymeleaf.suffix= ...
- JS OOP 概述
JS面向对象,大致内容 1.面向对象的基础 2.深入认识JS的函数 3.JS类的实现 4JS中共有成员,私有成员和静态成员 5.JS的反射 6.JS的继承 7.JS实现抽象类 8.JS事件设计模式 9 ...
- 二级菜单被banner遮住的解决方法
原因:z-index的问题 解决:在导航box加 position: relative; z-index: 4; 比banner 大就可以.然后在一级导航的 li 设置 相对定位 positio ...