Node.js中如何实现模块化编程并通过npm管理HTTP相关模块?

2026-05-19 21:261阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1180个文字,预计阅读时间需要5分钟。

Node.js中如何实现模块化编程并通过npm管理HTTP相关模块?

今天已是node学习的第二天,越往后面感觉越熟悉了,光芒对node说,为什么要学呢,因为之前学过一点云计算的东西,当时感觉没什么用,搞不下服务器、客户端这些。

今天是node学习的第二天,其实越往后面学越感觉有点熟悉的味道了,光针对于node来说哈,为什么呢,因为我之前学过一点云计算的东西,当时感觉没什么用搞了下服务器客户端这些,没想到这里还能用一用,至少看到服务器这些概念一点不陌生,看到npm一点不奇怪,我当时用的都是yum。

1.

Node.js中如何实现模块化编程并通过npm管理HTTP相关模块?

我们今天先看到127.0.0.1' ))

1.3

来一个案例,根据不同的url反映出不同的页面,这个应该很经典吧

// 1.获取到用户的url const 127.0.0.1'))

2.

我们接下来看到模块化,模块化是指解决一个复杂问题的时候,自顶向下逐层把系统划分到若干模块的过程,对于整个系统来说模块是可组合、分解和更换的单元。

在我们编程世界里面,模块化就是遵守固定的规则,把一个大文件拆分成独立并相互依赖的小模块,大家分工合作。

Node.js模块分类?

在我们node里面模块分为三个部分,第一个是内置模块:我们前面学的都是内置模块,fs、path、http等

第二个是自定义模块:什么叫做自定义模块,其实就是我们自己写的这个js文件他就是自定义模块

第三个是第三方模块:就是由第三方开发出来的模块,需要提前下载

然后 我们的模块都需要加载用到require

还会有模块作用域,也就是在我们自定义模块里面声明的变量函数,在外面的模块是访问不到的。

那么有没有办法来访问呢?

是有的,向外共享模块成员的方法要用到一个module对象,它是每个js自定义模块都有的内置对象,然后在这里面有一个关键的对象,exports,在我们前面,require这个自定义模块的时候得到的内容其实就是exports对象里面的内容,

所以说有时候为空,就是因为没给exports赋值,他就是一个空对象,我们在写的时候可以写成module.exports 也可以是exports

module.exports = { uname : '张三', sayHello : function() { console.log('hello node'); } }

const md = require('./module对象共享') console.log(md);

但是在模块化这里exports有几个要注意点的,始终要记住一点不管是exports还是module.exports他们虽然能完成一样的效果但是始终以为module.exports里面的数据为准。

为了防止混乱,最好不要将exports和module.exports混用

模块化规范

node遵循的是commenJS模块化的规范,包括我们前面说的module代表当前模块,exports是对外的接口,require用于加载模块都是commenJS规范的,但是我vue入了一点门被劝回来的那里,刚好看到后面应该遵循的都是es6模块化规范了,这个commenJS逐渐要淘汰了。

3

继续看到包和npm的一些内容,首先要明确什么叫包,第三方模块就叫包,包是由第三方个人和团队做出来的,都是免费的。

我们为什么要用包呢?

包是基于内置模块封装出来的,提提供了更高级、更简便的用法,其实就相当于jQuery和浏览器内置对象的关系,jq的ajax方法就是通过xhr封装来的撒。

npm

我们首先看到一个案例对时间格式化如果用我们的传统做法,也就是自定义模块的做法。

const module对象共享 = require("./module对象共享") function timeFormat(dataStr) { let date = new Date(dataStr) let y = date.getFullYear() let m = addZero(date.getMonth() + 1) let d = addZero(date.getDate()) let h = addZero(date.getDate()) let mm = addZero(date.getDate()) let s = addZero(date.getDate()) return `${y}-${m}-${d} ${h}:${mm}:${s}` } function addZero(n) { return n = n < 10? '0' + n : n } module.exports.timeFormat = timeFormat

const time = require('./格式化时间传统做法') // console.log(time); const date = new Date() console.log(date); console.log(time.timeFormat(date));

这就完成了一个对于时间格式化的操作,舒适还是有点麻烦,但我们现在有了npm就不一样了,可以用npm安装一个moment的包,安装导入查看文档api这三步曲走起。

const moment = require('moment') const timer = moment().format('YYYY-MM-DD HH:mm:ss') console.log(timer);

之前多少代码量,现在多少代码量,这就是为什么要用包。

最后说一下当你安装了包后文件夹多多出两个文件一个node_modules的文件夹这里面存放的npm下载的包文件,一个是pachage_lock.json的配置文件这里面是前面文件夹里面所有npm下载的包的详细信息这两个都不能去修改

最后如果要安装指定版本的包的话只需要在包名的后面添加@版本号

本文共计1180个文字,预计阅读时间需要5分钟。

Node.js中如何实现模块化编程并通过npm管理HTTP相关模块?

今天已是node学习的第二天,越往后面感觉越熟悉了,光芒对node说,为什么要学呢,因为之前学过一点云计算的东西,当时感觉没什么用,搞不下服务器、客户端这些。

今天是node学习的第二天,其实越往后面学越感觉有点熟悉的味道了,光针对于node来说哈,为什么呢,因为我之前学过一点云计算的东西,当时感觉没什么用搞了下服务器客户端这些,没想到这里还能用一用,至少看到服务器这些概念一点不陌生,看到npm一点不奇怪,我当时用的都是yum。

1.

Node.js中如何实现模块化编程并通过npm管理HTTP相关模块?

我们今天先看到127.0.0.1' ))

1.3

来一个案例,根据不同的url反映出不同的页面,这个应该很经典吧

// 1.获取到用户的url const 127.0.0.1'))

2.

我们接下来看到模块化,模块化是指解决一个复杂问题的时候,自顶向下逐层把系统划分到若干模块的过程,对于整个系统来说模块是可组合、分解和更换的单元。

在我们编程世界里面,模块化就是遵守固定的规则,把一个大文件拆分成独立并相互依赖的小模块,大家分工合作。

Node.js模块分类?

在我们node里面模块分为三个部分,第一个是内置模块:我们前面学的都是内置模块,fs、path、http等

第二个是自定义模块:什么叫做自定义模块,其实就是我们自己写的这个js文件他就是自定义模块

第三个是第三方模块:就是由第三方开发出来的模块,需要提前下载

然后 我们的模块都需要加载用到require

还会有模块作用域,也就是在我们自定义模块里面声明的变量函数,在外面的模块是访问不到的。

那么有没有办法来访问呢?

是有的,向外共享模块成员的方法要用到一个module对象,它是每个js自定义模块都有的内置对象,然后在这里面有一个关键的对象,exports,在我们前面,require这个自定义模块的时候得到的内容其实就是exports对象里面的内容,

所以说有时候为空,就是因为没给exports赋值,他就是一个空对象,我们在写的时候可以写成module.exports 也可以是exports

module.exports = { uname : '张三', sayHello : function() { console.log('hello node'); } }

const md = require('./module对象共享') console.log(md);

但是在模块化这里exports有几个要注意点的,始终要记住一点不管是exports还是module.exports他们虽然能完成一样的效果但是始终以为module.exports里面的数据为准。

为了防止混乱,最好不要将exports和module.exports混用

模块化规范

node遵循的是commenJS模块化的规范,包括我们前面说的module代表当前模块,exports是对外的接口,require用于加载模块都是commenJS规范的,但是我vue入了一点门被劝回来的那里,刚好看到后面应该遵循的都是es6模块化规范了,这个commenJS逐渐要淘汰了。

3

继续看到包和npm的一些内容,首先要明确什么叫包,第三方模块就叫包,包是由第三方个人和团队做出来的,都是免费的。

我们为什么要用包呢?

包是基于内置模块封装出来的,提提供了更高级、更简便的用法,其实就相当于jQuery和浏览器内置对象的关系,jq的ajax方法就是通过xhr封装来的撒。

npm

我们首先看到一个案例对时间格式化如果用我们的传统做法,也就是自定义模块的做法。

const module对象共享 = require("./module对象共享") function timeFormat(dataStr) { let date = new Date(dataStr) let y = date.getFullYear() let m = addZero(date.getMonth() + 1) let d = addZero(date.getDate()) let h = addZero(date.getDate()) let mm = addZero(date.getDate()) let s = addZero(date.getDate()) return `${y}-${m}-${d} ${h}:${mm}:${s}` } function addZero(n) { return n = n < 10? '0' + n : n } module.exports.timeFormat = timeFormat

const time = require('./格式化时间传统做法') // console.log(time); const date = new Date() console.log(date); console.log(time.timeFormat(date));

这就完成了一个对于时间格式化的操作,舒适还是有点麻烦,但我们现在有了npm就不一样了,可以用npm安装一个moment的包,安装导入查看文档api这三步曲走起。

const moment = require('moment') const timer = moment().format('YYYY-MM-DD HH:mm:ss') console.log(timer);

之前多少代码量,现在多少代码量,这就是为什么要用包。

最后说一下当你安装了包后文件夹多多出两个文件一个node_modules的文件夹这里面存放的npm下载的包文件,一个是pachage_lock.json的配置文件这里面是前面文件夹里面所有npm下载的包的详细信息这两个都不能去修改

最后如果要安装指定版本的包的话只需要在包名的后面添加@版本号