分享

nodejs入门

 风声之家 2015-05-09

nodejs入门之安装

分类: Javascript nodejs 315人阅读 评论(0) 收藏 举报

在官网下载安装包,windows系统可以下载mis安装包,双击自动安装即可,默认安装到C盘program files目录下。完成之后要添加系统变量右键我的电脑->高级系统设置->高级,在用户变量中path项中添加nodejs的安装路径,使用’;‘隔开,然后点击新建输入变量名NODE_PATH变量值C:\Program Files (x86)\nodejs\node_modules,也就是node_modules在系统中的路径。在nodejs文件夹中新建 test.js文件,输入 console.log(’right‘)保存。在控制台中执行该文件,如果输入right则说明安装成功。

nodejs入门之基础HTTP请求

分类: nodejs Javascript 1160人阅读 评论(0) 收藏 举报

新建一个js文件,姑且命名为index.js,输入如下代码:

[javascript] view plaincopy
  1. var http = require('http');  
  2. http.createServer(function(request, response){  
  3.     response.writeHead(200,{'Content-Type' : 'text/html'});  
  4.     response.write('hello world!');  
  5.     response.end();  
  6. }).listen(8888);  

第一行请求nodejs的HTTP服务模块,第二行使用http的createServer方法创建一个服务,这个方法会返回一个server对象,该对象有一个listen方法,带一个参数表示端口号。可以监听一个端口。
createServer可以接受一个函数作为参数,该函数会被自动添加到request事件中,并且接受两个参数request(请求)和response(答复)。在上面的代码中并没有用到request,因为没有请求的细节需要处理。writeHead()返回一个请求状态和http请求的类型,write()用于发送http请求的主体类容,之后调用end()完成响应。
在控制台输入node 根目录+\index.js,按下enter,在浏览器中查看127.0.0.1:8888,可以发现浏览器中有'hello world!'。


nodejs使用nodejs创建简单的静态文件服务器

分类: Javascript nodejs 3450人阅读 评论(0) 收藏 举报

在开始之前,应该好好规划一下项目的文件目录了。我的目录结构如下:

assets放置网站的静态文件css,js,img等;common存放项目的配置文件和一些通用文件;server存放服务处理文件,将要创建的静态文件服务就是放在此目录中; tpl放置的是模板文件也就是网页文件。
文件的下载格式主要是由'Content-Type'的值决定的,要想下载的文件能够正常工作就应该正确的设置不同文件的'Content-Type'值。mime.js文件存放了一些常用mime值:

[javascript] view plaincopy
  1. exports.mime = {  
  2.     "html" : "text/html",  
  3.     "css"  : "text/css",  
  4.     "js"   : "text/javascript",  
  5.     "json" : "application/json",  
  6.     "ico"  : "image/x-icon",  
  7.     "gif"  : "image/gif",  
  8.     "jpeg" : "image/jpeg",  
  9.     "jpg"  : "image/jpeg",  
  10.     "png"  : "image/png",  
  11.     "pdf"  : "application/pdf",  
  12.     "svg"  : "image/svg+xml",  
  13.     "swf"  : "application/x-shockwave-flash",  
  14.     "tiff" : "image/tiff",  
  15.     "txt"  : "text/plain",  
  16.     "wav"  : "audio/x-wav",  
  17.     "wma"  : "audio/x-ms-wma",  
  18.     "wmv"  : "video/x-ms-wmv",  
  19.     "xml"  : "text/xml"  
  20. };  
先来看server.js和FServer.js的类容:

[javascript] view plaincopy
  1. //  server.js    
  2.     var config = require('./common/config');    
  3.     var http   = require('http');    
  4.     var fs     = require('fs');    
  5.     var url    = require('url');    
  6.     var path   = require('path');    
  7.     var FServer   = require('./server/FServer');    
  8.     function index(){    
  9.         var indexPath = config.ui + '/index.html';    
  10.         fs.exists(indexPath, function(exists){    
  11.             if( !exists ) {    
  12.                 throw err;    
  13.             } else {    
  14.                 fs.readFile(indexPath, function(err, data){    
  15.                     if (err) {    
  16.                         throw err;      
  17.                     } else {    
  18.                         function onRequest(req, res){    
  19.                             // 取得文件路径    
  20.                             var pathname = url.parse(req.url).pathname;    
  21.                             // 获取文件扩展名(包含前置.)    
  22.                             var extname = path.extname( pathname );    
  23.                             var type = extname.slice(1);    
  24.                             // 获取下载文件在磁盘上的路径,    
  25.                             var realPath = config.root + pathname;    
  26.                             if ( extname === '' ) {    
  27.                                 res.writeHead(200, {'Content-Type':'text/html'});    
  28.                                 res.write(data);    
  29.                                 res.end();    
  30.                             } else {    
  31.                                 FServer.filesLoad(realPath, type, req, res);    
  32.                             }    
  33.                         }    
  34.                         http.createServer(onRequest).listen(config.port);    
  35.                     }    
  36.                 })    
  37.             }    
  38.         })    
  39.      }    
  40.     exports.index = index;    
  41.     
  42.     // FServer.js    
  43.     var fs   = require('fs');    
  44.     var mime = require('../common/mime').mime;    
  45.     function filesLoad(filePath, type, req, res){    
  46.         fs.exists(filePath, function(exists){    
  47.             if ( !exists ) {    
  48.                 res.writeHead(404, {'Content-Type''text/plain'});    
  49.                 // res.write();    
  50.                 res.end();    
  51.             } else {    
  52.                 fs.readFile(filePath, 'binary'function(err, file){    
  53.                     if ( err ) {    
  54.                         res.writeHead(500, {'Content-Type''text/plain'});    
  55.                         // res.write();    
  56.                         res.end();    
  57.                     } else {    
  58.                         res.writeHead(200, {'Content-Type': mime[type]});    
  59.                         res.write(file, 'binary');    
  60.                         res.end();    
  61.                     }    
  62.                 });    
  63.             }    
  64.         })    
  65.     }    
  66.     exports.filesLoad = filesLoad;    
上面引入了nodejs的内置模块http、fs、url、path,config和FServer是自定义模块,要读取文件首先要知道文件在磁盘上是否存在,还应当知道文件的类型才能达到想要的效果。运行程序可以发现css和javascript都下载正确,并且css效果在页面上正确渲染(javascript还没有写效果)

nodejs入门之使用nodejs展示一个网页

分类: nodejs Javascript 3129人阅读 评论(0) 收藏 举报
一个网页的内容其实就是一段字符串,response.write()可以接受一个字符串作为参数,所以很明显只需要把一个网页的内容作为参数传递给response.write()即可。例如:
[javascript] view plaincopy
  1. <span style="white-space:pre">  </span>var http = require('http');  
  2.     http.createServer(function(req, res){  
  3.         var html = '<html>'  
  4.         +'<head>'  
  5.         +'<title>nodejs</title>'  
  6.         +'</head>'  
  7.         +'<body>'  
  8.         +   'hello world! 1234'  
  9.         +'</body>'  
  10.         +'</html>';  
  11.         res.writeHead(200,{'Content-Type' : 'text/html'});  
  12.         res.write(html);  
  13.         res.end();  
  14.     }).listen(8888);  
在浏览器地址栏输入127.0.0.1:8888查看结果,打开控制台,可以发现网页的类容已经全部包含在浏览器中。
一个网页一般会包含css样式文件和javascript脚本文件,再上一个示例中没有这两个文件。现在可以添加简单的css和javascript文件查看效果:
[javascript] view plaincopy
  1. <span style="white-space:pre">  </span>var http = require('http');  
  2.     http.createServer(function(req, res){  
  3.         var html = '<html>'  
  4.         +'<head>'  
  5.         +'<title>nodejs</title>'  
  6.         +'<link rel="stylesheet" type="text/css" href="./bootstrap/css/bootstrap.min.css" />'  
  7.         +'<script type="text/javascript" src="./bootstrap/js/bootstrap.min.js"></script>'  
  8.         +'</head>'  
  9.         +'<body>'  
  10.         +   'hello world!hello world! 1234'  
  11.         +'</body>'  
  12.         +'</html>';  
  13.         res.writeHead(200,{'Content-Type' : 'text/html'});  
  14.         res.write(html);  
  15.         res.end();  
  16.     }).listen(8888);  
会发现css文件和javascript文件都没有被正确下载。这是因为这段代码中规定的'Content-Type'都是'text/html'类型,而且所有的response内容都相同,当然就看不到想要的效果。
我们知道css样式和javascript脚本有多种不同的引入方法,css样式可以使用外联样式、内部样式和内联样式,javascript可以使用外联和内部两种,既然外联不能正确显示,那么可以尝试其他方法。通过测试可以发现css内部样式和内联样式都可以在网页上看到效果,javascript同样。
[javascript] view plaincopy
  1. <span style="white-space:pre">  </span>var http = require('http');  
  2.     http.createServer(function(req, res){  
  3.         var html = '<html>'  
  4.         +'<head>'  
  5.         +'<title>nodejs</title>'  
  6.         +'<style type="text/css">'  
  7.         +'body{color:red;}'  
  8.         +'</style>'  
  9.         +'</head>'  
  10.         +'<body>'  
  11.         +   'hello world! 1234'  
  12.         +'</body>'  
  13.         +'</html>';  
  14.         res.writeHead(200,{'Content-Type' : 'text/html'});  
  15.         res.write(html);  
  16.         res.end();  
  17.     }).listen(8888);  
可以看到浏览器中的文字显示为红色。
但是这两种方式都不是现代web开发所提倡的。现代web开发提倡css样式和javascript使用外联的方式,以方便管理和重用。css文件和javascript文件都是静态文件,我们可以尝试建立一个简单的静态文件服务,这样就可以正确的在网页中使用外联文件了。


    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多