1、nodeJS的特点
- 单线程:
好处:是减少了内存开销;
缺点:就是一个用户造成了线程的崩溃,整个服务都崩溃了,其他人也崩溃了。 - 非阻塞I/O
不会傻等I/O语句结束,而会执行后面的语句。 - 事件驱动event-driven:不管是新用户的请求,还是老用户的I/O完成,都将以事件方式加入事件环,等待调度。
2、HTTP模块
Node.js中,将很多的功能,划分为了一个个mudule,大陆的书翻译为模块;这是因为,有一些程序需要使用fs功能(文件读取功能),有一些不用的,所以为了效率,你用啥,你就require啥。
//这个案例简单讲解http模块
//引用模块
const http = require("http");
//创建一个服务器,回调函数表示接收到请求之后做的事情
const server = http.createServer(function(req,res){
//req参数表示请求,res表示响应
console.log("服务器接收到了请求" + req.url);
res.writeHead(200,{"Content-Type":"text/html;charset=UTF-8"});
//设置响应头:文字编码
res.end();
});
//监听端口
server.listen(3000,"127.0.0.1");
- req的作用:
最关键的就是req.url属性,表示用户的请求URL地址。所有的路由设计,都是通过req.url来实现的。
我们比较关心的不是拿到URL,而是识别这个URL。
识别URL,用到两个新模块,第一个就是url模块,第二个就是querystring模块
- 字符串查询,用querystring处理
- 使用URL模块
3、模块
- node中的模块分为三部分:
1、系统自带模块
2、自定义模块:js文件和js文件之间有两种合作的模式:- 某一个js文件中,提供了函数,供别人使用。 只需要暴露函数就行了; exports.msg=msg;
- 某一个js文件,描述了一个类。 module.exports = People;
3、第三方模块
- 我们可以使用文件夹来管理模块,比如
var bar = require("bar");
那么Node.js将会去寻找node_modules目录下的bar文件夹中的index.js去执行。
每一个模块文件夹中,推荐都写一个package.json文件,这个文件的名字不能改。node将自动读取里面的配置。有一个main项,就是入口文件:
{
"name": "wwr",
"version": "1.0.1",
"main" : "app.js"
}
package.json文件,要放到模块文件夹的根目录去。
- 我们可以用package.json来管理依赖。
在cmd中,使用npm init可以初始化一个package.json文件,用回答问题的方式生成一个新的package.json文件。
- 这样解决两个问题
1.我们的依赖包,可能在随时更新,我们永远想保持更新,或者某持某一个版本;
2.项目越来越大的时候,给别人看的时候,没有必要再次共享我们引用的第三方模块。
别人使用我们的项目的时候,只需要npm install 即可安装相应的模块