【javascript】初识 NodeJS(三)

上节我们将 http 服务器(server.js)和请求路由模块(route.js)整合在一起了,当然这还不够,路由,顾名思义,是指我们要针对不同的 url 有不同的处理方式。

请求处理程序模块(requestHandlers)

function start() {
    console.log(‘Request handler "start" was called.‘);
}

function upload() {
    console.log(‘Request handler "upload" was called.‘);
}

exports.start = start;
exports.upload = upload;

下面我们需要将请求处理程序模块和路由模块相结合,修改主文件 index.js

var server = require(‘./server‘);
var route = require(‘./route‘);
var requestHandlers = require(‘./requestHandlers‘);

var handler = {};
handler[‘/‘] = requestHandlers.start;
handler[‘/start‘] = requestHandlers.start;
handler[‘/upload‘] = requestHandlers.upload;

server.start(route.route, handler);

正如所见,将不同的 url 映射到相同的请求处理程序上是很容易的:只要在对象中添加一个键为 ‘/‘ 的属性,对应 requestHandlers.start 即可,这样我们就可以干净简洁地配置 /start 和 / 的请求都交由 start 这一处理程序处理。在完成了对象的定义后,我们把它作为额外的参数传递给服务器。

var http = require(‘http‘);
var url = require(‘url‘);

function start(route, handler) {
    function onRequest(request, response) {
        var pathname = url.parse(request.url).pathname;
        console.log(‘Request ‘ + pathname + ‘ received.‘);

        route(handler, pathname);

        response.writeHead(200, {
            ‘Content-type‘: ‘text/plain‘
        });
        response.write(‘Hello node.js‘);
        response.end();
    }

    http.createServer(onRequest).listen(8888);
    console.log(‘server has started.‘);
}

exports.start = start;

这样我们就在 start() 函数里添加了 handler 参数,并且把 handler 对象作为第一个参数传递给了 route() 回调函数。

function route(handler, pathname) {
    console.log(‘Route a request for ‘ + pathname);

    if (typeof handler[pathname] === ‘function‘) {
        handler[pathname]();
    } else {
        console.log(‘No request handler found for ‘ + pathname);
    }
}

exports.route = route;

这样,我们就把服务器、路由和请求处理程序结合在一起了。现在我们启动应用程序并在浏览器中访问 http://localhost:8888/start,以下日志可以说明系统调用了正确的请求处理程序:

server has started.
Request /start received.
Route a request for /start
Request handler "start" was called.
Request /favicon.ico received.
Route a request for /favicon.ico
No request handler found for /favicon.ico
时间: 2024-10-24 19:03:04

【javascript】初识 NodeJS(三)的相关文章

JavaScript中的三种弹出对话框

JavaScript中的三种弹出对话框 *****本文来自互联网****** 学习过js的小伙伴会发现,我们在一些实例中用到了alert()方法.prompt()方法.prompt()方法,他们都是在屏幕上弹出一个对话框,并且在上面显示括号内的内容,使用这种方法使得页面的交互性更精彩,实际上我们经常会在进行网页浏览时简单这种类型的对话框,在用户与应用程序进行双向交流时,经常要用到对话框.avascript的三种对话框是通过调用window对象的三个方法alert(),confirm()和prom

函数原型属性-JavaScript深入浅出(三)

前两次总结了JavaScript中的基本数据类型(值类型<引用类型>,引用类型<复杂值>)以及他们在内存中的存储,对内存空间有了一个简单的了解,以及第二次总结了this深入浅出的用法,我们知道了this的用法取决于函数四种调用的方式. 这一次我们来对JavaScript中原型以及原型链做一个深入浅出的理解. JavaScript深入浅出系列 1)复杂值vs原始值&&内存空间 - JavaScript深入浅出(一) 2)this的用法 – JavaScript深入浅出

初识 Nodejs

1.HTTP:hyper text transmit protocal (超文本传输协议) 以下为利用http创建一个sever并连接相应的网页类容 http.createServer(function(request, response) {response.writeHead(200, {"Content-Type": "text/plain"});//相应行头response.write("Hello World");  //所要显示的网页

JavaScript中的三种弹出框

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <title>JavaScript中的三种弹出框</title> 5 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> 6 <script type="text/JavaScript"> 7 funct

一些有用的javascript实例分析(三)

原文:一些有用的javascript实例分析(三) 1 10 输入两个数字,比较大小 2 window.onload = function () 3 { 4 var aInput = document.getElementsByTagName("input"); 5 var aSpan = document.getElementsByTagName("span")[0]; 6 for(var i=0;i<aInput.length-1;i++){ 7 aInp

JavaScript高级编程(1)——JavaScript初识

一.javascript的简介 1.1 javascript的历史回顾. Javascript诞生于1995年.当时,它主要的目的是用来处理一些由服务器端处理的输入验证操作.在javascript没有问世之前,必须把表单数据发送到服务器端才能确定 是否没有填写某个必填项,是否输入无效值.Netscape navigator希望通过javascript解决这个问题.在人们普遍使用电话拨号上网的年代,等待验证返回是需要一种耐心的 行为. 自此以后,javascript逐渐成为市面上常见的浏览器必备

javascript 学习小结 (三) jQuery封装ajax尝试 by FungLeo

javascript 学习小结 (三) jQuery封装ajax尝试 by FungLeo 前言 在JS学习中,对于原生的很多东西我理解得并不透彻.但是使用jQuery来操作DOM,基本上还是非常熟练的.但是对于AJAX数据交互的处理,我不是很理解. 近期团队交给我一个后端全接口提供给我的项目.我要利用这些接口来自己组织前端代码.为了学习,我决定不使用VUE或者其他的前端框架来做.而是只使用jQuery框架,数据的部分全部使用拼接字符串的形式实现. 获取数据,显示数据,提交数据. 在这个项目中(

JavaScript基础(三)

JavaScript基础(三) for循环嵌套 循环嵌套不是什么特殊语法,就是说js中的许多语法结构都可以嵌套使用,for也可以 循环嵌套时,代码执行次数变多,通常使用是在2层左右 while循环 规则: 先进行条件检测,如果为true,执行循环体代码 再检测条件,再为true再执行循环体,以此类推 直到条件为false时循环结束 while (条件) { // 循环体 } for和while的使用场景 for循环适用于次数确定的重复操作(for使用较多) while循环适用于不确定次数的重复操

初识NodeJS,一个基于GoogleV8引擎的Javascript运行环境

思考 首先我们来思考一个问题:我们都知道几乎所有现代主流浏览器都全面支持了ECMAScript 5.1版标准,而JavaScript的标准是ECMAScript.那么我们就容易认为JavaScript是一种浏览器端的解释型编程脚本.那么脱离了浏览器,JavaScript还能够解释运行吗? 答案是肯定的,也就是说脱离了浏览器,在特定环境下JavaScript还是能运行的.JavaScript向来以Web网页的脚本语言而著称,但现在也可以用在许多非浏览器环境,例如node.js或者Apache Co