模块化开发

作者: i5yue | 来源:发表于2018-05-28 19:54 被阅读17次

    一、模块化

    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)

    相关文章

      网友评论

        本文标题:模块化开发

        本文链接:https://www.haomeiwen.com/subject/pvhnjftx.html