一、模块化
1、模块化代码结构
Node采用的模块化结构是按照CommonJS规范。
模块与文件其实是一一对应的关系,即加载一个模块,实际上就是加载对应的一个模块文件。
2、CommonJS 模块的特点
所有代码都运行在模块作用域不会污染全局作用域。
模块可以多次加载,但是只会在第一次加载时运行一次,然后运行结果就会被缓存,以后再加载,就直接读取缓存结果。想要模块再次运行,必须清除缓存。
模块加载的顺序,按照其在代码中出现的顺序。
3、模块的分类
文件模块:就是我们自己写的功能模块文件
核心模块:Node平台自带的一套基本的功能模块,也可以称之为Node平台的API
第三方模块:社区或者个人开发的功能模块,可以拿来主义。
4、模块化开发流程
创建模块(new module.js)
导出成员(module.export = {})
载入模块(var module1 = require(./module.js))
使用模块 (module1.fun)
二、require
1、简介
Node使用commonJS模块规范,内置require函数用于加载模块文件
require的基本功能是读取一个javaScrtip文件,然后返回改模块的exports对象
如果没有指定模块,就会报错
2、require 扩展名
加载文件时可以省略扩展名(require('./module'))
require('./module.js');此时按js文件执行
require('./module.json');此时按json文件执行
require('./module.node');此时按c++文件执行
3、require加载文件规则
通过./或../开头:则按照相对路径从当前文件所在文件夹开始需找模块。require('../file.js');上级目录下找file.js文件
通过/开头:则以系统根目录开始寻找模块。require('/users/home/file.js');以绝对路径方式需找。
如果参数字符串不以"./"或"/"开头,则表示加载的是一个默认提供的核心模块(位于node的系统安装目录中)
或者从当前目录向上搜索node_module目录中的文件;
4、require 加载目录的规则
如果require传入是一个目录路径,会自动查看该目录的package.json文件,然后加载main字段指定的入口文件。
如果package.json文件没有main字段,或者根本没有package.json文件,则默认找目录下的index.js文件作为模块。
5、什么是包
由于Node是一套轻内核的平台,虽然提供了一系列的内置模块,但是不足以满足开发者的需求,于是乎出现了包(package)的概念。
与核心模块类似,就是将一些预先设计好的功能或者API封装到一个文件夹,提供给开发者。
6、包的加载机制
包名的情况: 例如:require('http') 需要注意的情况。
先在系统核心(优先级最高)的模块找。
以后不要创建一些和现有的包重名的包。
然后再到当前的项目中node_modules中找。
7、什么是缓存区
缓存区就是内存中操作数据的容器,仅仅只是一个数据容器而已。
通过缓存区可以很方便的操作二进制数据
而且在操作大文件时必须有缓存区。
缓存区就如同一个大水缸,我先一次性把家里要用的水存储到水缸里,然后要用的时候就一次取一点,就如同用个水瓢一次瓢一点,这样的话轻松快捷。
8、为什么要有缓存区
JS是比较擅长处理字符串,但是早起的应用市场主要是用于处理HTML文档,不会有太大的篇幅处理数据,也不会接触到二进制的数据。
而在Node中操作数据、网络通信是没有办法完全以字符串的方式操作的。所以Node中引入一个二进制的缓冲区实现(Buffer)
网友评论