首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

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

    什么是模块化? 2. 无模块化时代 3. 传统模块化阶段 3.1. “对象”型模块 3.2. “仿Java类”型模块 3.3. “立即执行函数(IIFE)”型模块 3.4....什么是模块化模块化开发就是封装细节,提供使用接口,彼此之间互不影响,每个模块都是实现某一特定的功能。...优点肯定是有的 优点:传统模块化相比于无模块化时代,显然是进步的:减少了命名冲突,增强了模块的独立性; 但是 缺点同样明显 缺点: 1....百家争鸣:CommonJS、AMD、CMD JavaScript 在语言层面迟迟不推出模块化功能,这个背景下,各“民间组织”提出了CommonJS、AMD、CMD 模块化规范......CommonJS是一种只适用于JavaScript的静态模块化规范; 注:只适用于JavaScript,意味着它无法把CSS等前端资源纳入模块化管理范围,但显然CSS也是组成前端模块的重要部分; 注:静态模块化规范

    1.9K10

    前端模块化-总结_前端模块化规范

    先说说什么是模块化,就是将独立的功能代码封装成一个独立的文件,其他模块需要使用,在进行引用。 模块化有利于代码的拆分和架构上的解耦,模块化在服务端领域已经早已成熟,nodejs 也已经支持模块化。...因此前端早早就有了模块化技术,可每天醒来前端就多一个名词多一个框架的,发展实在迅猛,就前端模块化这些年的积累就有好几种,我们依次来看看。...个人认为,ES6模块化是以后的主流。...若使用 webpack ,webpack 是支持 es6 模块化的,所以就只要引用 babel-loader ,对 es6 的语法做处理即可 模块的导出是对象的引用 ES6模块化下的导出是对象的引用...CMD规范的模块化:用define()定义模块, seajs.use 引用模块。

    62220

    js模块化

    ---- 「这是我参与2022首次更文挑战的第27天,活动详情查看:2022首次更文挑战」 理解 什么是模块/模块化 将一个复杂的程序按照一定的规范,封装成几个块(文件),并进行组合在一起。...模块化的进化史 最早 最早,我们的js是写到一个文件中,想怎么写怎么写。...){ console.log(_$body) } return { foo:foo } })(jQuery) Moudle.foo() 为什么要模块化...比如不需要轮播图的模块,我们不需要引入 模块化的好处 避免命名冲突(减少命名空间污染) 更好的分离,按需加载 更高复用性 高可维护性 页面引入script 当我们需要引入多个js...script src='3.js'> 所以就带来了如下的问题 请求过多 依赖模糊 难以维护 因此也就需要模块化规范

    2.2K20

    what is 模块化?

    理解 我们先来了解一下,什么是模块化,以及模块化的进化史。 什么是模块/模块化 将一个复杂的程序按照一定的规范,封装成几个块(文件),并进行组合在一起。...模块化的进化史 最早 最早,我们的js是写到一个文件中,想怎么写怎么写。这种情况,也就是我们最原始的html的方式。会造成变量的全局污染。...){ console.log(_$body) } return { foo:foo } })(jQuery) Moudle.foo() 为什么要模块化...比如不需要轮播图的模块,我们不需要引入 模块化的好处 避免命名冲突(减少命名空间污染) 更好的分离,按需加载 更高复用性 高可维护性 页面引入script带来的问题 当我们需要引入多个js文件。...script> 复制代码 所以就带来了如下的问题 请求过多 依赖模糊 难以维护 因此也就需要模块化规范

    1.2K30

    再谈模块化

    当我们要开发模块化技术时,请牢记模块化系统至少具备下列2点功能: 定义模块接口:供外部代码调用该模块 隐藏模块的内部实现细节:模块的调用者/使用者无需关心模块内部的实现细节。...了解了模块,下面我们就来谈谈几种模块化方案。...ES6之前的模块化方案 (1)对象+闭包+立即执行函数方案 基于模块化的2个特点,在该方案中: 立即执行函数:隐藏内部实现细节 对象+闭包:形成接口,对外暴露模块功能,同时保持闭包活跃。...那么ES6模块化方案出现了!...ES6 模块化方案 ES6 的模块化方案结合了CMD和AMD的优点,例如: 模块语法简单,基于文件,即每个文件是一个模块 异步加载模块 ES6 目前还有一些浏览器不支持,可以使用其他工具进行编译,如:

    46520

    前端模块化

    前端模块化: 在前面学习中,我已经用了大量的篇幅解释了为什么前端需要模块化。 而且我也提到了目前使用前端模块化的一些方案:AMD、CMD、CommonJS、ES6。...在ES6之前,我们要想进行模块化开发,就必须借助于其他的工具,让我们可以进行模块化开发。 并且在通过模块化开发完成了项目后,还需要处理模块间的各种依赖,并且将其进行整合打包。...而webpack其中一个核心就是让我们可能进行模块化开发,并且会帮助我们处理模块间的依赖关系。...这就是webpack中模块化的概念。 打包如何理解呢? 理解了webpack可以帮助我们进行模块化,并且处理模块间的各种复杂关系后,打包的概念就非常好理解了。...grunt/gulp更加强调的是前端流程的自动化,模块化不是它的核心。 webpack更加强调模块化开发管理,而文件压缩合并、预处理等功能,是他附带的功能。

    22400

    Android模块化专题(一)- 模块化概念和路由

    本文是对模块化专题介绍的系列文章,包含了以下四部分:《我所理解的Android模块化(一)——概念和路由》,《我所理解的Android模块化(二)——模块通信和模块间服务调用》,《我所理解的Android...模块化(三)——模块可插拔单独编译运行》,《我所理解的Android模块化(四)——常见问题和注意事项》。...笔者在公司的项目中使用模块化的方式开发APP已经快一年的时间,其中经历过以模块化的方式来重构项目中一些相对来说业务比较独立的模块。...说完了笔者使用模块化的背景,再来谈谈我对Android模块化的一些理解,如果理解的很浅显或者狭隘的话,还请各位多多指教; 下面说几个概念:  模块化:指解决一个复杂问题时自顶向下逐层把系统划分成若干模块的过程...模块化之前的项目       ?            模块化之后的项目 ?

    81620
    领券