首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS模块化编程规范1——require.js

概述 require.js是各种网络APP中非常常见的JS依赖库,它其实不仅仅是个模块加载器那么简单。它背后蕴含了一个非常重要的设计,也就是JS模块化编程。...模块化是任何一个编程语言都会支持的设计,通过模块化能够将一个重要的问题拆分成一个个小的问题,并且模块与模块之间不关联(或者弱关联),减小的程序的开发难度。...这样,如果大家都约定使用同样的模块化规范设计,从一个框架到另外一个框架就没有成本,并且可以互相加载引入。 这里通过一个计算幂运算的例子,详细论述require.js的使用。 2....定义 模块化设计当然应该先定义一个模块了,这里定义一个乘法函数模块(Multiply.js): //自定义模块 define(function () { "use strict"; var...参考 【第67期】ES6 系列之模块加载方案 Javascript模块化编程(三):require.js的用法 JavaScript的模块化编程

3.2K10
您找到你想要的搜索结果了吗?
是的
没有找到

js模块化编程之彻底弄懂CommonJS和AMDCMD!(转)

JS中的模块规范(CommonJS,AMD,CMD),如果你听过js模块化这个东西,那么你就应该听过或CommonJS或AMD甚至是CMD这些规范咯,我也听过,但之前也真的是听听而已。 ...项目,将javascript语言用于服务器端编程。...这标志"Javascript模块化编程"正式诞生。...因为老实说,在浏览器环境下,没有模块也不是特别大的问题,毕竟网页程序的复杂性有限;但是在服务器端,一定要有模块,与操作系统和其他应用程序互动,否则根本没法编程。...在上例中,就是js目录下面的main.js,这个文件会第一个被require.js加载。由于require.js默认的文件后缀名是js,所以可以把main.js简写成main。

1.6K30

js 模块化发展

但文章中的 JS模块化还不等于前端工程的模块化,Web 界面是由 HTML、CSS 和 JS 三种语言实现,不论是 CommonJS 还是 AMD 包括之后的方案都无法解决 CSS 与 HTML 模块化的问题...Http 2.0 对 js 模块化的推动 js 模块化定义的再美好,浏览器端的支持粒度永远是瓶颈,http 2.0 正是考虑到了这个因素,大力支持了 ES 2015 模块化规范。...说到这里,还想顺便提一下最近流行起来的响应式编程(RxJS),响应式编程中有一个很核心的概念就是 observable,也就是 Rx 中的流(stream)。...一句话,模块化仍在路上。js 模块化的矛头已经对准了 css 与 html,这两位元老也该向前卫的 js 学习学习了。...未来 css、html 的模块化会自立门户,还是赋予 js 更强的能力,让两者的模块化依附于 js 的能力呢?

2.1K20

模块化】:JS 模块化极简史

——《软件工程》 在模块化编程中,开发者将程序分解成离散功能块(discrete chunks of functionality),并称之为模块。...传统模块化阶段 这一阶段,WEB 开发人员主要是利用 JS 语言的闭包、原型、函数作用域等特性,减少对全局命名空间的污染;方式方法各有不同,但结果都差不多,比较混乱... 3.1....CommonJS Node.js的诞生,使JavaScript扩展到了服务器端, 为了让JavaScript在服务器端能跟Java、Phyton一样编写大型程序,于是有了CommonJS模块化规范;...CommonJS是针对服务器端(非浏览器环境)的JavaScript开发,是Node.js的默认模块化规范; (2)....:通过JS的闭包、对象、自执行函数等语言特性,避免模块间的命名冲突,提高模块的内聚性,但无统一编程标准,也无法把模块间的依赖关系描述清晰; CommonJS:Node.js让JavaScript延伸到

1.8K10

js模块化例子

最近在看一本书,里面提到js模块化,觉得很有必要,所以记录下来 Game.js /** * This is the main class that handles the game life cycle..._canvas.height); }; ---- boardRenderer.js /** * 这个类负责绘制,棋盘,球 * @param context the 2d context to draw..._rows; }; ---- boardModel.js /** * 这个类是负责保存/验证/返回当前游戏的状态 * 如当前的玩家是谁、每个单元格放的是什么球、 * 是不是谁赢了 * @param...this.reset(); } /** * 0代表单元格为空,1代表单元格有红色球,2代表单元格有绿色球 * 因为怕以后忘记这些数字代表什么,干脆把数字存到常量里,代码看起来易懂, * 但是这么多字,前端的js...* ps.变量名全大写表示这是常量,这是一个js程序员之间的约定,表达为 CAPITAL_CASED。

4.6K20

Python|模块化编程

引言 模块化编程具备很多优点,尤其在复杂项目上体现更为明显。 Python模块化编程有助于开发者统筹兼顾和分工协作,并提升代码灵活性和可维护性,是编程开发者不可或缺的一项重要工具。...开始学习Python编程时,我们通常将项目所有代码放在一个源文件中进行编译实现。...但是随着深入学习和项目变得复杂起来时,这种做法将无法满足你快速找到你定义的函数(functions)或类(classes)的具体位置,这时模块化编程思想就有了用武之地。...虽然上述内容是一个虚构项目(与实际网页应用开发有别),但它很好的展示了模块化编程的思想,把整个项目划分成了独立的模块和包,有助于我们对模块化编程的理解。...小结 模块化编程的应用,有利于我们管理项目中需要变更或重建的模块,无需过多修改项目代码,提升项目的可维护性和灵活性;有利于提升我们编程的效率,避免重复造车轮的尴尬;有利于优化我们的项目代码结构,彰显项目的逻辑性

94020

Byzer 模块化编程

自身的一些缺陷在面对上面问题时,会导致非常大的问题: 大量重复 SQL 代码,无论完整的 SQL 语句或者 SQL 代码片段都难以复用,导致效率低下,难以协作 难以沉淀精细的(比如case when片段)或者模块化...除了本篇模块化编程以外,相辅相成的还有一个能力,就是模板编程的能力: Byzer Man:Byzer 模板编程入门。...版本的 Byzer Notebook ,还有 本地版本的 Byzer-desktop (基于VsCode), 他们都是以 Notebook 形式提供了对 Byzer 语言的支持,对于用户调试、管理和模块化...更多细节参考这篇专门的文章: Byzer Man:Byzer 模板编程入门 宏函数的使用 Byzer 也支持函数的概念,这个函数和 SQL 中的函数不同, Byzer 的宏函数是对 SQL 代码进行复用...在脚本中引入 Git 托管的 Byzer 代码 几乎所有的语言都有模块化管理代码的能力,比如 Java 的 jar, Python的 Pip, Rust 的crate 等。

94120

C模块化编程

模块化编程也一样,程序核心部分定义好接口,各个模块按照接口的定义去实现功能,然后把各个模块挂载到程序上即可,这个有点像Java的面向接口编程。如下图: ?...使用C进行模块化编程 用过C语言编程的人都知道C语言是没有接口的,所以怎么使用C语言进行模块化编程呢?...从上面的结果可以看到,我们可以注册不同的模块来提供不同的服务,模块化编程就这样实现了。 Are you kidding me?...C的模块化编程的确是这么简单,但是我们可以实现更强大的功能:使用动态链接库来实现模块化。...总结 由于模块化编程的灵活性和可扩展性非常好,所以很多流行的软件也提供模块化特性,如:Nginx、PHP和Python等。而这些软件使用的方法与本文介绍的大致相同,有兴趣可以查看这些软件的实现。

74230

JS 模块化历史简介

对于 JavaScript 来说,模块化是一个相对现代的概念,这篇文章会带你在 JavaScript 的世界里快速浏览模块化的历史进程~ Script 标签和闭包 在早些年间,JavaScript 就是直接写在...这种明确地声明依赖的写法让各个模块间的依赖都非常清晰,并且反过来促进了模块化的发展。 但是 RequireJS 并不是没有缺点。...Node.js 和 CommonJS CommonJS 模块系统是 Node.js 中众多革新的一个,也叫 CJS。...诚然,npm 主要服务于 CommonJS 模块和 JavaScript 包,由于简单的模块化语法和可复用性,大量 Node.js 和 web 浏览器的包出现在 npm 上,npm 也成为世界上最大的包管理器...ES6 规范中包含了一个原生的模块化系统,一般称之为 ECMAScript Modules(ESM)。

2.2K20

JS模块化和使用

JS模块化和使用 很久以前就知道js模块化开发可以使用require.js和sea.js,就一直没去看看。...什么是模块化 模块化是指在解决某一个复杂问题或者一系列的杂糅问题时,依照一种分类的思维把问题进行系统性的分解以之处理。模块化是一种处理复杂系统分解为代码结构更合理,可维护性更高的可管理的模块的方式。...这些规范的目的都是为了 JavaScript 的模块化开发,特别是在浏览器端的。目前这些规范的实现都能达成浏览器端模块化开发的目的。...RequireJS 和 Sea.js 都是模块加载器,倡导模块化开发理念,核心价值是让 JavaScript 的模块化开发变得简单自然。...回调函数的参数(math)对应的是引入模块(js/1_math.js)的别名(别名可以随意命名) */ require(['js/1_math'],function(math){ console.log

1.6K20

Js模块化导入导出

Js模块化导入导出 CommonJs、AMD、CMD、ES6都是用于模块化定义中使用的规范,其为了规范化模块的引入与处理模块之间的依赖关系以及解决命名冲突问题,并使用模块化方案来使复杂系统分解为代码结构更合理...// 1.js var a = 1; var b = function(){ console.log(a); } module.exports = { a: a, b: b...Module Definition规范,是浏览器端的模块化解决方案,CommonJS规范引入模块是同步加载的,这对服务端不是问题,因为其模块都存储在硬盘上,可以等待同步加载完成,但在浏览器中模块是通过网络加载的...--> CMD CMD通用模块定义,是SeaJS在推广过程中对模块定义的规范化产出,也是浏览器端的模块化异步解决方案,CMD和AMD的区别主要在于: 对于依赖的模块,AMD是提前执行(相对定义的回调函数..."; // 导入export import m1 from "./1.js"; // 不加{}即导入export default import {c} from "./1.js"; /

2.9K20
领券