2.模块/包与CommonJS

1.Node.js模块

  1. 内置的Node.js模块
const os = require('os');
console.log(os.hostname());

2.第三方的Node.js模块
当需要安装第三方的包时,可以在如下网址进行查询。
https://www.npmjs.com/
npm为我们提供了包管理文件package.json,在项目目录中,首先使用npm init就会生成package.json。

npm init
npm install --save 包名(要用的包)
npm install --save-dev 包名(debug用的包)

安装的包会在项目目录/node_modules中

使用包时与第一步相同,node首先会在内部查找,没有的话就去node_modules里面查找。

3.自定义的Node.js模块



在外面使用此自定义模块


  • 暴露多个内容:
const hello = ()=>{
    console.log('hello');
}

let msg = '你好';

module.exports.hello = hello;
module.exports.msg = msg;

在require的时候,module.export的名字就是greeting,相当于增加了一个顶层变量,所有的函数变量都要从这个顶层变量走。

  • 暴露一个类


  • 使用
// 使用一个类
const People = require('./src/people.js');
let xiaoming = new People('小明', '12');
xiaoming.sayHello();

2.nodejs提供的核心内置模块讲解

node.js官方文档
http://nodejs.cn/api/

2.1 url模块

url模块主要用于解析url地址

const url = require('url');
console.log(url);
  • url.parse(参数为url地址)
    将url字符串解析为对象
// 第二个参数,ture表示query为对象形式
console.log(url.parse('https://www.baidu.com:8080/api.php?from=li&course=node#level1',true));
输出结果
  • url.format(参数为url对象)
    将对象解析为字符串
const urlObject= {
  protocol: 'https:',
  slashes: true,
  auth: null,
  host: 'www.baidu.com:8080',
  port: '8080',
  hostname: 'www.baidu.com',
  hash: '#level1',
  search: '?from=li&course=node',
  query: { from: 'li', course: 'node' },
  pathname: '/api.php',
  path: '/api.php?from=li&course=node',
  href:
   'https://www.baidu.com:8080/api.php?from=li&course=node#level1' 
}
console.log(url.format(urlObject));
结果
  • url.resolve(url1,url2)
    将两段url解析成完整的url
console.log(url.resolve('https://www.baidu.com','/api/list.php'));

2.2 querystring模块

const querystring = require('querystring');
console.log(querystring);
  • querystring.stringify(参数对象)
    用于将对象转换成以&形式相连的参数字符串
console.log(querystring.stringify({name:'qian',course:['nodejs','vue.js'],from:''}));

结果:

name=qian&course=nodejs&course=vue.js&from=

也可以自定义分隔符

// 生成的字符串以,分隔
console.log(querystring.stringify({name:'qian',course:['nodejs','vue.js'],from:''},','));
name=qian,course=nodejs,course=vue.js,from=

键值对之间以:分割

// 键值之间以:分割
console.log(querystring.stringify({name:'qian',course:['nodejs','vue.js'],from:''},',',':'));
name:qian,course:nodejs,course:vue.js,from:
  • query.parse(字符串)
    将字符串转化成对象
console.log(querystring.parse('name=qian&course=nodejs&course=vue.js&from='));
console.log(querystring.parse('name=qian,course=nodejs,course=vue.js,from=',','));
console.log(querystring.parse('name:qian,course:nodejs,course:vue.js,from:',',',':'));
  • querystring.escape(字符串)
    将字符串进行编码
console.log(querystring.escape('北京'));
console.log(querystring.unescape('%E5%8C%97%E4%BA%AC'));

2.3 http模块

  • 创建服务器
// http模块

// 引用http模块
const http = require("http");

// 创建一个服务器。回调函数表示接收到请求之后做的事情
let server = http.createServer(function(req, res) {
    // req参数表示请求,res表示响应
    console.log('服务器接收到了请求'+req.url);

    //此方法向服务器发出信号,表明已发送所有响应头和主体,该服务器应该视为此消息已完成。 必须在每个响应上调用此 response.end() 方法。
    res.end();
});

//监听端口
server.listen(3000,'127.0.0.1');
输入网址localhost:3000
   // 此方法用于设置响应头
    res.writeHead(200, {
        'Content-Type': 'text/plain;charset=UTF8',
    });
  • get请求
//  https Get请求
const https = require('https');
let options = {
    hostname : 'api.douban.com',
    port : 443,
    method : 'GET',
    path : '/v2/movie/top250'
} 

let request = https.request(options, (response)=>{
    console.log(response);
})

request.on('error', (error)=>{
   console.log(error);
})

request.end();
  • post请求
    在使用post请求时,将数据拆分成了众多的数据块chunk,通过特定事件,将这些小数据块有序的传递给回调函数。
const http = require ("http");
const querystring = require("querystring");
http.createServer(function(req,res) {
    // 如果请求来源是/dopost ,并且请求方法时post
    if(req.url == "/dopost" && req.method.toLowerCase() == "post"){
        // 使用post请求时,将数据拆分成了众多的数据块chunk,通过特定事件,将这些小数据块有序的传递给回调函数。
        let alldata = "";
        req.addListener("data", function(chunk) {
            alldata += chunk;
        });

        // 全部传输完毕
        req.addListener("end", function() {
            let dataString = alldata.toString();
            // 将请求数据转换为对象类型,我们就可以直接使用
            let dataObj = querystring.parse(dataString);
            res.end();
        });
    }
}).listen(80, '127.0.0.1');
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 222,104评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,816评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,697评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,836评论 1 298
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,851评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,441评论 1 310
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,992评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,899评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,457评论 1 318
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,529评论 3 341
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,664评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,346评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,025评论 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,511评论 0 24
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,611评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 49,081评论 3 377
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,675评论 2 359

推荐阅读更多精彩内容