web学习笔记(四十八)

目录

1.初次装包后多了哪些文件

2.团队协作的问题

[2.1 如何剔除 node_modules](#2.1 如何剔除 node_modules)

[2.2 快速创建 package.json](#2.2 快速创建 package.json)

[2.3 dependencies 节点](#2.3 dependencies 节点)

[2.4 devDependencies 节点](#2.4 devDependencies 节点)

2.5一次性下载所有的包

[2.6 卸载包](#2.6 卸载包)

[3. 淘宝镜像](#3. 淘宝镜像)

[4. 模块的加载机制](#4. 模块的加载机制)

[4.1 优先从缓存中加载](#4.1 优先从缓存中加载)

[4.2 内置模块的加载机制](#4.2 内置模块的加载机制)

[4.3 自定义模块的加载机制](#4.3 自定义模块的加载机制)

[4.4 第三方模块的加载机制](#4.4 第三方模块的加载机制)

[4.5 目录作为模块](#4.5 目录作为模块)


1.初次装包后多了哪些文件

初次装包完成后,在项目文件夹下多一个叫做 node_modules 的文件夹和 package-lock.json 的配置文件。其中:node_modules 文件夹用来存放所有已安装到项目中的包。require() 导入第三方包时,就是从这个目录中查找并加载包。package-lock.json 配置文件用来记录 node_modules 目录下的每一个包的下载信息,例如包的名字、版本号、下载地址等。

注意:程序员不要手动修改 node_modules 或 package-lock.json 文件中的任何代码,npm 包管理工具会自动维护它们。

2.团队协作的问题

因为第三方包的体积过大,一次我们进行团队协作分享资源时需要将node_modules剔除后再分享。

2.1 如何剔除 node_modules

在项目中创建一个.gitignore文件夹,用来存放忽略的文件,然后将node_modules文件夹,添加到 .gitignore 忽略文件中。

2.2 快速创建 package.json

npm 包管理工具提供了一个快捷命令,可以在执行命令时所处的目录中,快速创建 package.json 这个包管理配置文件: npm init -y

  • 上述命令只能在英文的目录下成功运行!所以,项目文件夹的名称一定要使用英文命名,不要使用中文,不能出现空格。
  • 运行 npm install 命令安装包的时候,npm 包管理工具会自动把包的名称和版本号,记录到 package.json 中。

2.3 dependencies 节点

package.json 文件中,有一个 dependencies 节点,专门用来记录您使用 npm install 命令安装了哪些包

2.4 devDependencies 节点

如果某些包只在项目开发阶段会用到,在项目上线之后不会用到,则建议把这些包记录到 devDependencies 节点中。与之对应的,如果某些包在开发和项目上线之后都需要用到,则建议把这些包记录到 dependencies 节点中。

|-----------------|--------------------|
| dependencies | 用于存放项目上线和开发环境都需要的包 |
| devDependencies | 用于本地环境开发时所需要的包 |

2.5一次性下载所有的包

当拿到一个项目后,需要先通过npm install(或者是npm i命令)命令将项目中需要的所有包给下载下来,否则就会报错。

2.6 卸载包

可以运行 npm uninstall 包名 命令,来卸载指定的包,npm uninstall 命令执行成功后,会把卸载的包,自动从 package.json 的 dependencies 中移除掉。

3. 淘宝镜像

在使用 npm 下包的时候,默认从国外的 https://registry.npmjs.org/ 服务器进行下载,此时,网络数据的传输需要经过漫长的海底光缆,因此下包速度会很慢。因此我们可以切换 npm 的下包镜像源 将npm的下载地址改为淘宝镜像的地址。

在终端输入下面的命令就可以设置淘宝的镜像。

javascript 复制代码
npm config set registry https://registry.npm.taobao.org/

通过下面的命令可以查看当前的npm地址,来判断是否设置成功

javascript 复制代码
npm config get registry

通过下面的命令可以删除淘定镜像

javascript 复制代码
npm config delete registry

4. 模块的加载机制

4.1 优先从缓存中加载

模块在第一次加载后会被缓存。 这也意味着多次调用 require() 不会导致模块的代码被执行多次。

注意:不论是内置模块、用户自定义模块、还是第三方模块,它们都会优先从缓存中加载,从而提高模块的加载效率。

4.2 内置模块的加载机制

module内置模块是由 Node.js 官方提供的模块,内置模块的加载优先级最高

例如,require('fs') 始终返回内置的 fs 模块,即使在 node_modules目录下有名字相同的包也叫做 fs也会加载内置的fs,而不是fs包。

4.3 自定义模块的加载机制

使用 require() 加载自定义模块时,必须指定以 ./ 或 ../ 开头的路径标识符。在加载自定义模块时,如果没有指定 ./ 或 ../ 这样的路径标识符,则 node 会把它当作内置模块或第三方模块进行加载。同时,在使用 require() 导入自定义模块时,如果省略了文件的扩展名,则 Node.js 会 按**.js、.json、.node**的顺序分别尝试加载,如果都没有那就会进行报错。

4.4 第三方模块的加载机制

如果传递给 require() 的模块标识符不是一个内置模块,也没有以 './' 或 '../' 开头,则 Node.js 会从当前模块的父目录开始,尝试从 /node_modules 文件夹中加载第三方模块。如果没有找到对应的第三方模块,则移动到再上一层父目录(只会查找父目录,而不会查找兄弟目录,如果只有兄弟目录中包含了/node_modules,而其他地方没有,那也会报错)中,进行加载,直到文件系统的根目录。

例如,假设在 'C:\Users\project\foo.js' 文件里调用了 require('tools'),则 Node.js 会按以下顺序查找:

C:\User\project\node_modules\tools

C:\Users\node_modules\tools

C:\node_modules\tools

4.5 目录作为模块

当把目录作为模块标识符,传递给 require() 进行加载的时候,有三种加载方式:

  • 在被加载的目录下查找一个叫做 package.json 的文件,并寻找 main 属性,作为 require() 加载的入口
  • 如果目录里没有 package.json 文件,或者 main 入口不存在或无法解析,则 Node.js 将会试图加载目录下的 index.js 文件。
  • 如果以上两步都失败了,则 Node.js 会在终端打印错误消息,报告模块的缺失:Error: Cannot find module 'xxx'
相关推荐
向前看-26 分钟前
验证码机制
前端·后端
燃先生._.1 小时前
Day-03 Vue(生命周期、生命周期钩子八个函数、工程化开发和脚手架、组件化开发、根组件、局部注册和全局注册的步骤)
前端·javascript·vue.js
南宫生2 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
高山我梦口香糖2 小时前
[react]searchParams转普通对象
开发语言·前端·javascript
sanguine__2 小时前
Web APIs学习 (操作DOM BOM)
学习
m0_748235242 小时前
前端实现获取后端返回的文件流并下载
前端·状态模式
冷眼看人间恩怨3 小时前
【Qt笔记】QDockWidget控件详解
c++·笔记·qt·qdockwidget
m0_748240253 小时前
前端如何检测用户登录状态是否过期
前端
black^sugar3 小时前
纯前端实现更新检测
开发语言·前端·javascript