Containjs 1.0 Containjs 是什么? Containjs 是一个基于 Commonjs 模块管理规范的 浏览器端 的 JavaScript 模块加载器(目前为非标准的,代码会持续迭代,现阶段主要提供思路,想集结各路 js 大神一同完善) Containjs 项目地址 Containjs 使用 获取 Containjs 去 gitHub 下载 页面下载文件. 目录结构 Containjs 目前的目录结构非常简单,项目中 JavaScript 都放在一个 "js" 目录…
1.什么是模块化 文件作用域 通信规则 加载 require 导出 exports 2.CommonJs模块规范 在Node中的Javascript还有一个很重要的概念:模块概念 模块作用域 使用require方法来加载模块 语法: var 自定义变量名称 = require('模块') 两个作用: 执行被加载模块中的代码 得到被加载模块中的exports导出接口对象 使用exports借口对象来导出模块中的成员 Node中的模块作用域,默认文件中所有的成员在当前文件模块有效 对于希望可以被其他…
就在这个周末,npm 超过了 cpan ,成为地球上最大的软件模块仓库. npm 的模块都是 JavaScript 语言写的,但浏览器用不了,因为不支持 CommonJS 格式.要想让浏览器用上这些模块,必须转换格式. 本文介绍浏览器加载 CommonJS 的原理,并且给出一种非常简单的实现. 一.原理 浏览器不兼容CommonJS的根本原因,在于缺少四个Node.js环境的变量. module exports require global 只要能够提供这四个变量,浏览器就能加载 CommonJ…
就在这个周末,npm 超过了 cpan ,成为地球上最大的软件模块仓库. npm 的模块都是 JavaScript 语言写的,但浏览器用不了,因为不支持 CommonJS 格式.要想让浏览器用上这些模块,必须转换格式. 本文介绍浏览器加载 CommonJS 的原理,并且给出一种非常简单的实现. 一.原理 浏览器不兼容CommonJS的根本原因,在于缺少四个Node.js环境的变量. module exports require global 只要能够提供这四个变量,浏览器就能加载 CommonJ…
前言 本人记忆力一般,为了让自己理解<深入浅出Node.js-朴灵>一书,会在博客里记录一些关键知识,以后忘了也可以在这里找到,快速回想起来 Node通过require.exports.module实现CommonJS模块规范的 路径分析 require('http') //如http.fs.path,速度仅次于缓存加载,它在node源代码编译过程中已经被编译成二进制代码,其加载速度最快 require('./a.txt') //以.或者..开始的相对路径模块 require('/a.txt'…
ES6 模块与 CommonJS 模块的差异 CommonJS 模块输出的是一个值的拷贝,ES6 模块输出的是值的引用. CommonJS 模块是运行时加载,ES6 模块是编译时输出接口. CommonJS 加载的是一个对象(即module.exports属性),该对象只有在脚本运行完才会生成.而 ES6 模块不是对象,它的对外接口只是一种静态定义,在代码静态解析阶段就会生成. 在 ES6 之前,社区制定了一些模块加载方案,最主要的有 CommonJS 和 AMD 两种.前者用于服务器,后者用于…
本规范致力于描述一类可以同时适用于客户端和服务器端的模块系统.该系统中的模块拥有自己的作用域,可以从其他模块导入单例对象,或者对外提供 API. Require require 是一个函数对象. require 函数接受一个称为模块标识符的参数. require 函数返回外部模块提供的 API. 当发生循环依赖时,一个外部模块被其依赖模块导入时,它可能未被完全执行.在此种情况下,当前模块调用 require 函数所返回的对象必须包含该外部模块已经准备好的输出物. 如果不能返回所请求的模块,则 r…
浅析JS模块规范 随着JS模块化编程的发展,处理模块之间的依赖关系成为了维护的关键. AMD,CMD,CommonJS是目前最常用的三种模块化书写规范. CommonJS CommonJS规范是诞生比较早的.NodeJS就采用了CommonJS.是这样加载模块: var modA= require('modA'); modA.start(); 这种写法适合服务端,因为在服务器读取模块都是在本地磁盘,加载速度很快.但是如果在客户端,加载模块的时候有可能出现“假死”状况.比如上面的例子中clock的…
Javascript模块化编程(AMD&CommonJS) 前端模块化开发的价值:https://github.com/seajs/seajs/issues/547 模块的写法 查看 AMD规范 背景一: 目前,通行的Javascript模块规范共有两种:CommonJS和AMD.在CommonJS中,有一个全局性方法require(),用于加载模块.假定有一个数学模块math.js,就可以像下面这样加载. var math = require('math'); 然后,就可以调用模块提供的方法:…
参考 : https://blog.csdn.net/xcymorningsun/article/details/52709608 1.CommonJS 模块规范 (同步加载模块): var math = require('math'); // 其中 math 是模块实例 math.add(2,3); 2. AMD 模块规范  (异步加载依赖模块): require(['math'], function (math) { // 其中 math 是模块实例 math.add(2, 3); });…