您的位置:

js引入commonjs,Js引入split

本文目录一览:

CommonJS规范

Node应用由模块组成,采用CommonJS规范。每一个文件就是一个模块,有自己的作用域。在一个文件里面定义的变量、函数、类都是私有的,对其他文件不可见。

引入模块打印结果如下图:

exports.xxx 是给exports对象添加属性,可以多次添加.

引入模块打印结果如下图:

module.exports 是给module对象的exports属性赋值,再次添加会将上次的值覆盖掉,只能添加一次。

那CommonJS暴露的到底是什么呢?

CommonJS规范规定,每个模块内部,module变量表示当前模块。这个变量是一个对象,它的exports属性(module.exports)是对外的接口。暴露模块的本质是:将exports对象暴露。加载某个模块,其实是加载该模块的exports属性。

那在模块中,我们并未看到定义module这个变量,这个变量到底是谁提供的呢?

我们通过在模块中打印==argument.callee== 可以观察到当前执行的函数对象

什么是【CommonJs】

CommonJs 是一种 JavaScript 语言的模块化规范,它通常会在服务端的 Nodejs 上使用。项目是由多个模块组成的,模块和模块之间的调用,需要各个模块有相同规范的 API,这样一来在使用的过程中不会有那么多的学习成本,并且对于单个模块来说是类聚的。

在 CommonJs 的模块化规范中,每一个文件就是一个模块,拥有自己独立的作用域、变量、以及方法等,对其他的模块都不可见。CommonJS规范规定,每个模块内部,module 变量代表当前模块。这个变量是一个对象,它的 exports 属性(module.exports)是对外的接口。加载某个模块,其实是加载该模块的 module.exports 属性。require 方法用于加载模块。

模块化规范给项目带来极大的好处,在业务复杂,模块众多的大型项目中,开发者都遵循相同的规则来开发各自的模块,他们通过规范来约束模块的定义,大家不需要太多的沟通或者大量的文档来说明自己的模块使用规则,成千上万的模块就这样生产,并能够容易的使用。它的意义不仅是让模块看起来很规范,在合作开发、社区中传播中也起到了重大的作用。

CommonJS与ES6模块化的具体使用方式

所以:只需要将需要暴露给外部的变量或者方法 设置为exports的属性 就行,

可以把exports看做一个全局对象,把所有暴露出来的函数和变量都存放在里面

1.先写个6.js文件

CommonJS规范规定,每个模块内部,module变量代表当前模板,这个变量是一个对象,他的 exports 属性(相当于 module.exports )是对外的接口。 这里详情请看我的另一篇文章: module、exports 和 require的关系

加载某个模块,其实是加载该模块的module.exports属性。require方法用于加载模块

ES6模块化的使用方法:(注!因为CommonJS类库众多,以及 CommonJS 和 ES6 之间的差异,所以无法直接兼容es6。)

直接/按需导出:可使用多个 用变量/常量的方式

导入:需要用按需导入 {解构} 的方式获取

默认导出:只能使用一个 (default属性只有es6才有)可以用引入对象定义多个属性,但这样在引入后调用的时候,更麻烦。

导入:优点:可以直接使用文件做接收参数且不用结构。

重命名export和import

如果导入的多个文件中,变量名字相同,即会产生命名冲突的问题,为了解决该问题,ES6为提供了重命名的方法,当你在导入名称时可以这样做:

如果想看CommonJS与ES6模块化的原理 可以去看我另一篇文章

[秦圆圆]大佬写的 require和import的区别

[大孩子气]大佬写的 require/exports、import/export 的区别

[七分sunshine!]大佬写的# 前端模块化工具 requireJs的使用;

js引入commonjs,Js引入split

2022-11-23
头部引入js文件(外部引入js文件)

本文目录一览: 1、dreamweaver 如何插入js 2、JS外链式在html头部引入无效的问题 3、求助:HTML点击按钮调用JS文件或者直接调用JS代码? dreamweaver 如何插入js

2023-12-08
htmljs编程笔记(html代码笔记)

本文目录一览: 1、html代码和JS代码有什么区别 2、如何在html中调用js函数 3、JavaScript学习笔记之数组基本操作示例 4、HTML5初学者笔记 5、《web前端笔记7》js字符—

2023-12-08
html代码怎么用js引入,html js引入

本文目录一览: 1、如何在 JS 中嵌入 HTML 代码 2、求助:HTML点击按钮调用JS文件或者直接调用JS代码? 3、HTML中引入css和js的方法 如何在 JS 中嵌入 HTML 代码 大段

2023-12-08
怎么引入js和css,js需要引入吗

本文目录一览: 1、怎么在页面里引入bootstrap的css和js文件 2、用js文件怎么引入其他js文件和css文件 3、ES6 如何引入js css等问题 4、HTML中引入css和js的方法

2023-12-08
js的2种commonjs,js有几种类型

本文目录一览: 1、javascript模块化是什么及其优缺点介绍 2、CMD 规范是不是就是 commonJS 规范 3、简述什么是commonjs,以及其与nodejs的关系 4、什么是【Comm

2023-12-08
动态引入js文件的问题,js文件引入js文件

本文目录一览: 1、javascript怎么动态引入js文件 2、如何在js文件中动态加载另一个js文件? 3、如何在js中动态引入或加载js文件 javascript怎么动态引入js文件 有三种方法

2023-12-08
html代码怎么用js引入,在html中引入js的三种方法

本文目录一览: 1、JS如何在页面中插入HTML代码 2、HTML中引入css和js的方法 3、HTML如何插入js? 4、如何在 JS 中嵌入 HTML 代码 5、求助:HTML点击按钮调用JS文件

2023-12-08
php引入js然后(html怎么引入php)

本文目录一览: 1、如何在php里调用js文件 2、如何使用php文件引入外界的js文件 3、在php文件中,如何引入js 4、js中引用php变量,然后php中再次引用js的变量,怎么操作 如何在p

2023-12-08
js模块规范cjs,js模块规范esm

本文目录一览: 1、在node环境下怎么使用commonjs模块去使用require方法 2、如何理解前端模块化 3、js代码规范问题 JavaScript判断语句规范 4、使用 MockJs — 实

2023-12-08
html怎么并入js文件,html中如何引入js文件

2022-11-25
cssjs文件的引入,在js中引入css文件

本文目录一览: 1、如何在css中 加入js呢 2、怎么在页面里引入bootstrap的css和js文件 3、用js文件怎么引入其他js文件和css文件 4、tp5怎么引入css,js文件 5、HTM

2023-12-08
php引入js函数(jsphp)

2022-11-10
js装入css(怎么引入js)

本文目录一览: 1、外部js怎么引用css? 2、怎样用JS来添加CSS样式 3、javascript如何添加css类 外部js怎么引用css? 你说的是用jQuery里的addClass方法吧(抱歉

2023-12-08
java加载js,java加载js引擎

2022-11-24
用web如何引用js,怎么引用网页

本文目录一览: 1、intellij idea java web怎么引入js 2、如何在 Web 浏览器中启用 JavaScript 3、如何引入一个 js文件 4、intellij idea jav

2023-12-08
js高级程序设计笔记14(js高级程序设计笔记14页)

本文目录一览: 1、JavaScript高级程序设计 该怎么看 2、JavaScript学习笔记之数组基本操作示例 3、JS中有关sort以及return的问题 JavaScript高级程序设计 该怎

2023-12-08
web怎么引用js(web引用css)

本文目录一览: 1、如何引入一个 js文件 2、intellij idea java web怎么引入js 3、远程WEB应用如何调用本地js方法 如何引入一个 js文件 新建Javascript 类型

2023-12-08
HTML引入JS的三种方式

2023-05-19
link加载js文件(link引入js文件)

本文目录一览: 1、如何实现JavaScript动态加载CSS和JS文件 2、linux下如何让网站支持用一个连接加载多个CSS或者JS文件 3、javascript或jquery如何实现延迟加载js

2023-12-08