模块化的进化过程_前端培训

发布时间:2021年04月26日作者:atguigu浏览次数:680

模块化的进化过程

1 全局function模式

编码: 将不同的功能封装成不同的全局函数

问题: 污染全局命名空间, 容易引起命名冲突或数据不安全,而且模块成员之间看不出直接关系

function m1(){
  //…
}
function m2(){
  //…
}

2 命名空间模式:简单对象封装

作用: 减少了全局变量,解决命名冲突

问题: 数据不安全(外部可以直接修改模块内部的数据)

let myModule = {
  data: ‘www.baidu.com’,
  foo() {
    console.log(`foo() ${this.data}`)
  },
  bar() {
    console.log(`bar() ${this.data}`)
  }
}
myModule.data = ‘other data’ // 能直接修改模块内部的数据
myModule.foo() // foo() other data

这样的写法会暴露所有模块成员,内部状态可以被外部改写。

3 IIFE模式:匿名函数自调用

作用: 数据是私有的, 外部只能通过暴露的方法操作

编码: 将数据和行为封装到一个函数内部, 通过给window添加属性来向外暴露接口

问题: 如果当前这个模块依赖另一个模块怎么办?

<!– index.html文件 –>
<script type=”text/javascript” src=”module.js”></script>
<script type=”text/javascript”>
    myModule.foo()
    myModule.bar()
    console.log(myModule.data) //undefined 不能访问模块内部数据
    myModule.data = ‘xxxx’ //不是修改的模块内部的data
    myModule.foo() //没有改变
</script>// module.js文件
(function(window) {
  let data = ‘www.baidu.com’
  //操作数据的函数
  function foo() {
    //用于暴露有函数
    console.log(`foo() ${data}`)
  }
  function bar() {
    //用于暴露有函数
    console.log(`bar() ${data}`)
    otherFun() //内部调用
  }
  function otherFun() {
    //内部私有的函数
    console.log(‘otherFun()’)
  }
  //暴露行为
  //为了在模块内部调用全局变量,必须显式地将其他变量输入模块,让依赖关系更明显。
  window.myModule = { foo, bar }
})(window, jQuery)

最后得到的结果:

 模块化的进化过程_前端培训

4 IIFE模式增强:引入依赖

// module.js文件
(function(window, $) {
  let data = ‘www.baidu.com’
  //操作数据的函数
  function foo() {
    //用于暴露有函数
    console.log(`foo() ${data}`)
    $(‘body’).css(‘background’, ‘red’)
  }
  function bar() {
    //用于暴露有函数
    console.log(`bar() ${data}`)
    otherFun() //内部调用
  }
  function otherFun() {
    //内部私有的函数
    console.log(‘otherFun()’)
  }
  //暴露行为
  //为了在模块内部调用全局变量,必须显式地将其他变量输入模块,让依赖关系更明显。
  window.myModule = { foo, bar }
})(window, jQuery) // index.html文件
  <!– 引入的js必须有一定顺序 –>
  <script type=”text/javascript” src=”jquery-1.10.1.js”></script>
  <script type=”text/javascript” src=”module.js”></script>
  <script type=”text/javascript”>
    myModule.foo()
  </script>

想要了解跟多关于前端培训课程内容欢迎关注尚硅谷前端培训,尚硅谷除了这些技术文章外还有免费的高质量前端培训课程视频供广大学员下载学习。


上一篇:
下一篇:
相关课程

java培训 大数据培训 前端培训

关于尚硅谷
教育理念
名师团队
学员心声
资源下载
视频下载
资料下载
工具下载
加入我们
招聘岗位
岗位介绍
招贤纳师
联系我们
全国统一咨询电话:010-56253825
地址:北京市昌平区宏福科技园2号楼3层(北京校区)

深圳市宝安区西部硅谷大厦B座C区一层(深圳校区)

上海市松江区谷阳北路166号大江商厦3层(上海校区)

武汉市东湖高新开发区东湖网谷(武汉校区)

西安市雁塔区和发智能大厦B座3层(西安校区)

成都市成华区北辰星拱青创园综合楼3层(成都校区)