Reputation: 3414
I'm trying to do a simple server answering to url /page1 and /page2; this is the module dispatcher.js:
var HttpDispatcher = function() {
this.listeners = { get: [ ], post: [ ] };
this.errorListener = function() { }
}
HttpDispatcher.prototype.on = function(method, url, cb) {
this.listeners[method].push({
cb: cb,
url: url
});
}
HttpDispatcher.prototype.onGet = function(url, cb) {
this.on('get', url, cb);
}
HttpDispatcher.prototype.onPost = function(url, cb) {
this.on('post', url, cb);
}
HttpDispatcher.prototype.onError = function(cb) {
this.errorListener = cb;
}
HttpDispatcher.prototype.dispatch = function(req, res) {
var parsedUrl = require('url').parse(req.url, true);
var method = req.method.toLowerCase();
if(this.listener[method][parsedUrl.pathname]) this.listener[method][parsedUrl.pathname](req, res)
else this.errorListener(req, res);
}
module.exports = new HttpDispatcher();
and this is the server:
var dispatcher = require('./node_modules/httpdispatcher');
var http = require('http');
dispatcher.onGet("/page1", function(req, res) {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Page One');
});
dispatcher.onPost("/page2", function(req, res) {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Page Two');
});
http.createServer(function (req, res) {
dispatcher.dispatch(req, res);
}).listen(80, '127.0.0.1');
But when i try to execute the server, i get the error:
D:\Works\Web Resources\NODE JS\node_modules\httpdispatcher.js:33
if(this.listener[method][parsedUrl.pathname]) this.listener[method][parsedUr ^ TypeError: Cannot read property 'get' of undefined
Anyone knows why?
Upvotes: 4
Views: 8105
Reputation: 3783
It may be a typo
if(this.listener[method][parsedUrl.pathname]) this.listener[method][parsedUrl.pathname](req, res)
I think it is this.listeners
(with -s)
2nd question (from comments):
HttpDispatcher.prototype.on = function(method, url, cb) {
this.listeners[method][url] = cb;
}
That way, you can check if URL exists (like you already do), and access the function like you already do.
Upvotes: 4