nodejs模块化的好处:1、代码解耦,可以提高代码的复用性;2、可以提高代码的可维护性;3、可以提高代码的可读性;4、可以实现按需加载;5、可以解决命名冲突;6、方便管理依赖。
本教程操作环境:windows7系统、nodejs 12.19.0版,DELL G3电脑。
什么是模块化?
在编程领域中,模块化就是遵守固定的规则,把一个大文件拆分成独立并且相互依赖的多个小模块.通俗来讲就是一个js文件可以使用另一个js文件中的数据.
模块化有什么好处?
1、代码解耦,可以提高代码的复用性
2、可以提高代码的可维护性
3、可以提高代码的可读性
4、可以实现按需加载
5、可以解决命名冲突
6、方便管理依赖
模块化的产生也带来了模块作用域,同函数作用域相似,在自定义模块中定义的变量、方法等,只能在当前作用域内被访问,这种访问限制,有效的解决了变量污染的问题。
模块规范
模块化规范就是对代码进行模块化的拆分与组合时,需要遵守的那些规则,例如:
使用什么样的语法格式来引用模块
在模块中使用什么样的语法格式向外暴露成员
模块化规范的好处:大家都遵守同样的模块化规范写代码,降低了沟通的成本,极大方便了各个模块之间的相互调用,利人利己
模块规范种类:
CommonJS 规范:nodejs中遵守的就是commonjs规范。
ES6 模块化规范:(前后端通用的模块化规范;Node.js、Vue、React 中都能使用!)
CMD 和 AMD 模块化规范(较少使用): CMD--sea.js, AMD-require.js
-
UMD 叫做通用模块定义规范(Universal Module Definition),它可以通过运行时或者编译时让同一个代码模块在使用 CommonJs、CMD 甚至是 AMD 的项目中运行。它没有自己专有的规范,是集结了 CommonJs、CMD、AMD 的规范于一身。
区别:
1. 对于依赖的模块,AMD 是提前执行,CMD 是延迟执行。
2. CMD 推崇依赖就近,AMD 推崇依赖前置。
nodejs模块分类
- 内置模块 --- fs(文件系统模块).path(路径模块).http(网络操作模块)...
const fs = require("fs"); //node提供的基础模块,可以直接导入使用
- 自定义模块 --- 用户自己创建的.js文件
const m = require("./js文件名");//注意其中是相对路径,后缀名.js可加可不加
- 第三方模块 --- 由第三方个人或团队开发出来的模块,通常叫做包,使用前需要下载导入
const moment = require('moment');// 使用前需要通过npm i moment 命令安装该包
模块的导入导出
导入
使用require()方法加载模块
注意:使用require方法加载其他模块时,会执行被加载模块中的代码
导出
- 在每个自定义模块中都有一个module对象,它里面存储了和当前模块有关的信息,其中一个属性exports可以将模块成员暴露,供外界使用.加载某个模块时得到的就是module.exports这个属性指向的一个空对象.
- 若想使用该模块中的数据,可以向module.exports这个属性中添加属性值供外界使用
- 为了简化向外共享成员的代码,node提供了exports对象.默认情况下,exports和module.exports指向同一个对象.
注意: 使用require()方法导入模块时,导入的结果永远以module.exports指向的对象为准
exports和module.exports的使用误区
exports = { username: 'ls', gender: '男' } module.exports = exports; module.exports.age = '20'; // 导入后的结果为 {username:'ls',gender:'男',age:'20'} exports = { username: 'ls', gender: '男' } module.exports.age = '20'; module.exports = exports; // 导入后的结果为 {username:'ls',gender:'男'} exports = { username: 'ls', gender: '男' } exports = module.exports; module.exports.age = '20'; // 导入后的结果为 {age:'20'}
所以使用时尽量只使用其中一个方法,避免造成不必要的麻烦
更多node相关知识,请访问:nodejs 教程!!
以上是nodejs模块化有什么好处的详细内容。更多信息请关注PHP中文网其他相关文章!

Include:1)AsteeplearningCurvedUetoItsVasteCosystem,2)SeochallengesWithClient-SiderEndering,3)潜在的PersperformanceissuesInsuesInlArgeApplications,4)ComplexStateStateManagementAsappsgrow和5)TheneedtokeEedtokeEedtokeEppwithitsrapideDrapidevoltolution.thereedtokeEppectortorservolution.thereedthersrapidevolution.ththesefactorsshesssheou

reactischallengingforbeginnersduetoitssteplearningcurveandparadigmshifttocoment oparchitecent.1)startwithofficialdocumentationforasolidFoundation.2)了解jsxandhowtoembedjavascriptwithinit.3)

ThecorechallengeingeneratingstableanduniquekeysfordynamiclistsinReactisensuringconsistentidentifiersacrossre-rendersforefficientDOMupdates.1)Usenaturalkeyswhenpossible,astheyarereliableifuniqueandstable.2)Generatesynthetickeysbasedonmultipleattribute

javascriptfatigueinrectismanagbaiblewithstrategiesLike just just in-timelearninganning and CuratedInformationsources.1)学习whatyouneedwhenyouneedit

totlecteactComponents通过theusestatehook,使用jestandReaCtteTingLibraryToSigulation Interactions andverifyStatAtaTeChangesInTheUI.1)renderthecomponentAndComponentAndComponentAndCheckInitialState.2)模拟useclicklicksorformsormissionsions.3)

KeysinreactarecrucialforopTimizingPerformanceByingIneFefitedListupDates.1)useKeyStoIndentifyAndTrackListelements.2)避免使用ArrayIndicesasKeystopreventperformansissues.3)ChooSestableIdentifierslikeIdentifierSlikeItem.idtomaintainAinainCommaintOnconMaintOmentStateAteanDimpperperFermerfermperfermerformperfermerformfermerformfermerformfermerment.ChosestopReventPerformissues.3)

ReactKeySareUniqueIdentifiers usedwhenrenderingListstoimprovereConciliation效率。1)heelPreactrackChangesInListItems,2)使用StableanDuniqueIdentifiersLikeItifiersLikeItemidSisRecumended,3)避免使用ArrayIndicesaskeyindicesaskeystopreventopReventOpReventSissUseSuseSuseWithReRefers和4)

独特的keysarecrucialinreactforoptimizingRendering和MaintainingComponentStateTegrity.1)useanaturalAlaluniqueIdentifierFromyourDataiFabable.2)ifnonaturalalientedifierexistsistsists,generateauniqueKeyniqueKeyKeyLiquekeyperaliqeyAliqueLiqueAlighatiSaliqueLiberaryLlikikeuuId.3)deversearrayIndiceSaskeyseSecialIndiceSeasseAsialIndiceAseAsialIndiceAsiall


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版
中文版,非常好用

Dreamweaver Mac版
视觉化网页开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境