Node

Node中文网:http://Nodejs.cn/


(一)全局变量global

  • node中有一个全局变量global,是node中最大的一个对象,相当于浏览器中的window对象。
  • global中的成员在使用时,可以省略global,这点也类似浏览器中的window

global中的成员

  • console,不是浏览器中的console对象,是node中的console
  • process,和进程相关的对象
  • setInterval,同理,也是node中的,不是浏览器中的
  • require(),它是全局对象global中的一个方法,用于在js文件中引入另外的文件
  • __dirname,当前执行文件的绝对路径(在js文件中使用)
  • __filename,当前执行文件的绝对路径,包含文件名(在js文件中使用)
console.log(123);
if (5 > 4) {
    console.log('大于');
}
global.console.log(1234);
global.setTimeout(() => {
    console.log('suibian');
}, 2000);
console.log(__dirname);
console.log(__filename);
//输出结果
//123
//大于
//1234
///Users/lisiyi/AJAX/code/public
///Users/lisiyi/AJAX/code/public/demo.js
//suibian

(二)Node核心模块

要使用一个模块的话必须先加载(引入)该模块。

1.path模块(处理路径模块)

  • 操作文件的时候经常要对文件的路径做处理,或者获取文件的后缀,使用 path 模块。
  • path 是 Node 本身提供的 API,专门用来处理路径。
  • path 仅仅用来处理路径的字符串,不一定存在对应的物理文件。

使用方法:

// 使用核心模块之前,首先加载核心模块
let path = require('path');
// 或者
const path = require('path');

path模块中的方法:


代码举栗:

const path = require('path');

// extname -- 获取文件后缀
console.log(path.extname('index.html')); // .html
console.log(path.extname('index.coffee.md')); // .md

// join -- 智能拼接路径
console.log(path.join('/a', 'b', 'c')); // \a\b\c
console.log(path.join('a', 'b', 'c')); // a\b\c
console.log(path.join('/a', '/b/../c')); // \a\c
console.log(path.join('/a', 'b', 'index.html')); // \a\b\index.html
console.log(path.join(__dirname, 'a', 'index.html')); // 得到一个绝对路径

2.fs模块(文件操作模块)

引入模块的时候,可以使用var、let,但是建议使用const,因为我们不希望它改变。

//加载模块,得到一个对象。
const fs = require('fs');
console.log(fs);

readFile异步读取文件。其中[编码]可选,默认输出buffer类型的数据。

const fs = require('fs');
// fs.readFile(文件路径, [编码], 回调函数处理读取的内容);
fs.readFile('index.html', 'utf-8', (err, data) => {
    //err表示是否有错误,有错误的话err表示错误信息,是一个字符串。没有错误err是undefined
    if (err) {
        console.log(err); //若有错误,输出错误
        return; //阻止后续代码
    }
    console.log(data); //输出读取的内容
});

writeFile异步写入文件。会将文件中原有的内容覆盖掉。若写入文件不存在,则会自动创建文件。

const fs = require('fs');
// 调用writeFile方法,写入文件
// fs.writeFile(文件路径,写入的内容,回调函数查看是否有错误);
fs.writeFile('demo.txt', 'how are you', (err) => {
    if (err) {
        console.log(err);
    }
    else {
        console.log('success');
    }
})

3.querystring模块(查询字符串处理模块)

//加载模块
const querystring = require('querystring');
// parse方法是将查询字符串转换成JS对象,是querystring对象中封装的,不是JSON.parse。
let result = querystring.parse('id=123&name=zs&age=20');
console.log(result); // { id: '123', name: 'zs', age: '20' }
console.log(querystring.stringify(result)); //id=123&name=zs&age=20

4.url模块

旧的API使用:

const url = require('url');
//let res = url.parse('http://www.baidu.com:80/test.html?id=123&age=20');
let res = url.parse('test.html?id=123&age=20'); //url不完整也可以解析
console.log(res); //解析出一个对象
//获取参数
console.log(res.query); //id=123&age=20
//引入querystring处理res.query
const querystring = require('querystring');
console.log(querystring.parse(res.query)); //{ id: '123', age: '20' }

新的API使用:实例化URL的时候,必须传递一个完整的url,否则会报错

const myUrl = new URL('http://www.baidu.com/test.html?id=123&age=20');
// const myUrl = new URL('test.html?id=123&age=20'); //报错,无效的url
//传两个参数组成完整的url,不会报错
// const myUrl = new URL('test.html?id=123&age=20', 'http://www.xyz.com'); 
console.log(myUrl); //解析出一个对象,包含了url的各个组成部分
//比旧的API多了searchParams
console.log(myUrl.searchParams); //URLSearchParams { 'id' => '123', 'age' => '20' }
//获取id参数
console.log(myUrl.searchParams.id); //undefined
console.log(myUrl.searchParams.get('id')); //必须调用searchParams对象中的get方法来获取

(三)http模块(服务器处理模块)

node不同于Apache,安装完node并没有一个能够提供Web服务环境,需要使用http模块自己来搭建Web服务器。

  • http是一个系统模块,让我们能够通过简单的流程创建一个Web服务器。

1.使用http模块搭建Web服务器

//加载http模块
const http = require('http');
//调用http模块中的createServer方法,创建服务器
const server = http.createServer();
//启动服务器,并且要为服务器设置端口
server.listen(3000, () => {
    console.log('服务器启动了');
});
//添加request事件,用于处理所有的http请求
server.on('request', () => {
    console.log('你的请求我收到了');
});

2.如何对浏览器的请求作出响应

const http = require('http');
const server = http.createServer();
server.listen(3000, () => {
    console.log('服务器启动了');
});
server.on('request', (req, res) => {
    //事件处理函数有两个参数
    //req表示request,所有和请求相关的信息都可以通过request对象来接收
    //res表示response,所有和响应相关的都可以使用response对象来处理
    console.log('你的请求我收到了');
    //通过res.setHeader()方法来设置响应头,若不设置会出现中文乱码
    res.setHeader('Content-Type','text/html; charset=utf-8');
    //通过res对象的end方法来对浏览器作出响应
    //res.end()方法的作用是将响应报文(行、头、体)返回给浏览器
    res.end('你的请求我收到了');
});

3.根据不同url处理不同请求

const http = require('http');
const server = http.createServer();
server.listen(8000, () => console.log('start'));
server.on('request', (req, res) => {
    /*
    req.url 表示请求的url,形如/index.html
    req.method 表示请求方式,比如GET
    req.headers 表示所有的请求头,是一个对象
    */
    let url = req.url;
    //判断,根据url返回信息
    if (url === 'index.html') {
        //读取index.html并返回内容
        res.setHeader('content-type', 'text/html;charset=utf-8');
        res.end('你请求的是index.html');
    }
    else if (url === '/getMsg') {
        //读取数据并返回
        res.setHeader('content-type', 'text/html;charset=utf-8');
        res.end('你请求的是getMsg接口')
    }
    else {
        //服务器没有浏览器请求的文件或接口
        res.setHeader('content-type', 'text/html;charset=utf-8');
        res.statusCode = 404; //不存在,设置状态码为404
        res.end('你请求的文件不存在')
    }
})

4.处理浏览器POST方式提交的数据

const http = require('http');
const server = http.createServer();
server.listen(8000, () => console.log('start'));
server.on('request', (req, res) => {
    //判断是否是POST方式请求
    if (req.method === 'POST' && req.url === '/addMsg') {
        console.log(1234);
        //服务器端接收数据的时候是分块接收的
        //需要data事件,将浏览器发送过来的数据拼接到一起
        let str = '';
        req.on('data', (chunk) => {
            str += chunk;
        });
        //如果已经将全部数据接收到了,则触发end事件,在这个事件中可以获取到所有数据
        req.on('end', () => {
            console.log(str); 
        });
    }
})

使用postman测试:



终端输出结果:

1234
name=lisiyi&content=imlisiyi

5.处理外部静态资源

为不同的文件类型设置不同的 Content-Type

  • .html:text/html
  • .css:text/css
  • .js:application/javascript
  • .jpg:image/jpg
response.setHeader('Content-Type', 'text/css');
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,681评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,710评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,623评论 0 334
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,202评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,232评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,368评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,795评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,461评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,647评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,476评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,525评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,226评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,785评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,857评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,090评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,647评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,215评论 2 341

推荐阅读更多精彩内容

  • Node.js是目前非常火热的技术,但是它的诞生经历却很奇特。 众所周知,在Netscape设计出JavaScri...
    Myselfyan阅读 4,061评论 2 58
  • 个人入门学习用笔记、不过多作为参考依据。如有错误欢迎斧正 目录 简书好像不支持锚点、复制搜索(反正也是写给我自己看...
    kirito_song阅读 2,439评论 1 37
  • 模块化公布自己的模块功能. 其他模块调用另外的模块. 公布方法 如果要输出一个键值对象{},可以利用exports...
    httIsHere阅读 507评论 0 0
  • 最近,关于“努力”的文不少,从作者的视角看到了现今人们的各种状态。印象很深的一句话是“你只是看起来很努力”。想到自...
    熹尤阅读 364评论 0 0
  • 5点,闹钟把我从睡梦中叫醒,看看外面雾蒙蒙的阴着天。有点不想起了,可是一想到昨天才立下的志愿,今天就放弃,简直就是...
    红红的火焰V阅读 117评论 0 3