【Node.js】模块化:

文章目录


1、模块化的基本概念

2、Node.js 中模块化

【1】Node.js 中模块的分类
【2】加载模块
【3】模块作用域

【3-1】模块作用域

【3-2】模块作用域好处

【4】向外共享模块作用域中的成员

【4-1】 module 对象

【4-2】 module.exports 对象

module.exports默认导出为{}

【4-3】 共享成员时的注意点

【4-4】exports 对象

【4-5】exports 和 module.exports 的使用误区

【5】模块化规范

3、npm与包(包/依赖/插件)

【1】包的基本知识:

【npm官网】https://www.npmjs.com/

【npm下载包官网】 https://registry.npmjs.org/

【规范包结构】https://yarnpkg.com/zh-Hans/docs/package-json





【2】开发属于自己的包

【2-1】需要实现的功能

【2-2】初始化包的基本结构

【2-3】初始化 package.json

关于更多 license 许可协议相关的内容,可参考 https://www.jianshu.com/p/86251523e898

【注】需要去npm官网搜索查看是否存在该名字的包

【2-4】在 index.js中定义包的相关功能(如:格式化时间的方法)

【2-5】 将不同的功能进行模块化拆分


【2-6】 编写包的说明文档

【3】发布包

【3-1】注册 npm 账号https://www.npmjs.com/(建议用谷歌浏览器,Edge校验时图片显示不全)

【3-2】登录 npm 账号

【注】npm需要使用官方镜像源发布,不要使用淘宝镜像

bash 复制代码
//查看镜像源使用状态:
npm get registry
//全局切换镜像源:
npm config set registry http://registry.npm.taobao.org
//全局切换官方镜像源
npm config set registry https://registry.npmjs.org/
bash 复制代码
npm i nrm -g
#切换官方镜像源
nrm use npm


【3-3】 把包发布到 npm 上(包名没有被占用)

bash 复制代码
npm login
npm publish
npm unpublish 包名 --force

【3-4】删除已发布的包


【Dev-sidecar】Github 加速、Stack Overflow 加速、NPM 加速

官方网址:https://github.com/docmirror/dev-sidecar/releases/tag/v1.7.3

备份地址:https://lhnq31mi09.feishu.cn/file/TtW6byRKmoVLqkx1vSycSQjZnzh

4、模块的加载机制

【1】优先从缓存中加载
【2】内置模块的加载机制
【3】自定义模块的加载机制
【4】第三方模块的加载机制
【5】目录作为模块
相关推荐
Q_Q19632884751 小时前
python的电影院座位管理可视化数据分析系统
开发语言·spring boot·python·django·flask·node.js·php
一枚前端小能手4 小时前
⚡ Node.js服务器慢得像蜗牛,性能优化实战分享
前端·node.js·dnodejs
Cecilialana7 小时前
在安装 node-sass 时出现的编译问题
webpack·node.js
前端双越老师9 小时前
【干货】使用 langChian.js 实现掘金“智能总结” 考虑大文档和 token 限制
人工智能·langchain·node.js
一枚小小程序员哈19 小时前
基于Vue + Node能源采购系统的设计与实现/基于express的能源管理系统#node.js
vue.js·node.js·express
海上彼尚21 小时前
使用 npm-run-all2 简化你的 npm 脚本工作流
前端·npm·node.js
开发者小天21 小时前
为什么 /deep/ 现在不推荐使用?
前端·javascript·node.js
一枚小小程序员哈1 天前
基于Vue的个人博客网站的设计与实现/基于node.js的博客系统的设计与实现#express框架、vscode
vue.js·node.js·express
刘永胜是我1 天前
node版本切换
前端·node.js
我是哈哈hh1 天前
【Node.js】ECMAScript标准 以及 npm安装
开发语言·前端·javascript·node.js