美文网首页js css html
js之模块化(1)

js之模块化(1)

作者: 哆啦C梦的百宝箱 | 来源:发表于2022-07-12 14:48 被阅读0次

我们知道在刚开始,JavaScript语言是没有模块化的概念,但是随着前端能干的事情越来越多,事情越来越复杂,模块化就显得不可或缺,当然,这还要得益于node.js和commonjs走入了人们的视线。

关于commonjs

我们先来看一下,它在维基百科的定义

CommonJS 是一个项目,其目标是为 JavaScript 在网页浏览器之外创建模块约定。创建这个项目的主要原因是当时缺乏普遍可接受形式的 JavaScript 脚本模块单元,模块在与运行JavaScript 脚本的常规网页浏览器所提供的不同的环境下可以重复使用。

由此可见commonjs主要是服务于服务器端的,并不是前端,但载体确是javascript,所以对推动前端模块化,具有深远影响。

关于为什么要使用前端模块化

当然,如果业务场景简单,是没有必要使用。但是随着逻辑的复杂,我们遇到了各种各样的问题。可以想一想,你是否在开发中也遇到了下面的问题。

  • 随着代码的增多,我们会让html和js代码解耦,也就是说,我们会把js代码放在一个单独的文件中,使用script引入。但是随着更多开发者的加入,我们会引入许多js文件,如下:
<script src="./a.js"></script>
<script src="./b.js"></script>
//a.js
var name='123';
//b.js
var name ='456';

其实这个时候问题就已经来了,因为没有封闭作用域的概念,声明的变量存在在全局中,造成全局污染,而开发者本身又很难保证自己维护的js文件不和其他的js文件发生冲突,于是代码开发和维护简直成了噩梦。

  • 为了解决全局污染,命名冲突的问题,聪明的开发者想到,那我们就使用命名空间就好了嘛,其实这里已经有一点模块化的意思了。如下
<script src="./a.js"></script>
<script src="./b.js"></script>
//a.js
app.moduleA = {}
app.moduleA.name = 'lilei'
//b.js
app.moduleB = {}
app.moduleB.name = 'hanmeimei'
  • 这种方式解决了命名冲突,但是还有一个问题,就是我们在b模块中可以获取moduleA的name,同时在moduleA毫无感知的情况下去修改它。

    为了解决这个问题,聪明的开发者利用了javascript的函数作用域,闭包的特性去解决这一问题。如下

<script src="./a.js"></script>
<script src="./b.js"></script>
//a.js
app.moduleA = (function(){
  var name='lilei';
  return function getName(){return name};
})()
//b.js
app.moduleB = (function(){
  var name='hanmeimei';
  return function getName(){return name};
})()

这样我们就保护了我们的数据。但是还是有不足的地方,者两个文件的加载有先后顺序,如果加载的两个文件之间有依赖,维护这种依赖关系就变得很复杂。

所以,综上所述,前端需要模块化,并且模块化不光要处理全局变量污染、数据保护的问题,还要很好的解决模块之间依赖关系的维护。

相关文章

  • js模块化规范

    title: js模块化date: 2019-01-30 17:49:22tags: js 1.无模块化 缺点:1...

  • js之模块化(1)

    我们知道在刚开始,JavaScript语言是没有模块化的概念,但是随着前端能干的事情越来越多,事情越来越复杂,模块...

  • 07.Vuex共享数据 (VUE全栈开发学习笔记)

    模块化管理 store/index.js store/mod1.js main.js views/xxx.vue

  • webpack基础笔记

    webpack基础 1.前端工程化 实际的前端开发: 模块化:(js的模块化,css的模块化,资源的模块化) 组件...

  • js模块化规范

    一、js模块化1、模块化规范: script CommonJS AMD CMD ES6 modules 2、scr...

  • 模块化开发

    js模块化开发vue模块化开发

  • JavaScript模块化开发

    JavaScript模块化开发:按照模块化的方式来组织JS的代码,相比于面向对象变成,模块化的范围更广泛。 1:发...

  • 模块化

    - 模块化 -AMD-CMD规范- requireJS实践- r.js打包工具使用 1、为什么要使用模块化?###...

  • ES6模块化-常量/固定方法打包为文件并调用

    1. 常量模块化 (1)url.js中定义常量集合 (2)index.vue中调用常量 2. 固定方法模块化 (1...

  • Javascript 模块化

    Javascript 模块化发展的历史精读 js 模块化发展直接定义依赖 (1999): 由于当时 js 文件非常...

网友评论

    本文标题:js之模块化(1)

    本文链接:https://www.haomeiwen.com/subject/tbaobrtx.html