广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >分析web前端模块化开发
  • 618
分享到

分析web前端模块化开发

2024-04-02 19:04:59 618人浏览 安东尼
摘要

这篇文章主要介绍“分析web前端模块化开发”,在日常操作中,相信很多人在分析WEB前端模块化开发问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析web前端模块化开发”的疑惑

这篇文章主要介绍“分析web前端模块化开发”,在日常操作中,相信很多人在分析WEB前端模块化开发问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析web前端模块化开发”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

  1. 命名冲突

  首先从一个简单的习惯开始。

  由于以前一直做 JavaEE 开发的缘故,在 javascript 开发中,我已经习惯将项目中的一些通用功能抽象出来,形成一个个的独立函数,以便于实现代码复用,如:

  function CSS(element, attr) { // 获取 element 元素的 attr 对应的 CSS 属性值

  // ...

  }

  function offset(element) { // 获取 element 元素在文档中的位置坐标

  // ...

  }

  并把这些封装的函数放在统一的 tools.js 文件中。

  如果页面功能实现需要使用到这些函数,则直接通过 引入即可。

  前期感觉一切都好,大家也都觉得写这样的工具文件对开发来说很方便,直到使用越来越多,页面功能越来越复杂,大家要实现的需求也越来越多样。

  这时有人就抱怨,因为引入了 tools.js 文件,如果要定义一个能够设置 css 属性值的函数,那么就只有取另外的函数名称(如 setCss )而不能再使用 css 这个函数名称了,同样如果要设置一个元素在整个文档中的定位坐标,也不能再使用 offset 这个函数名称,因为那样的话,就与 tools.js 文件中已定义的函数名称冲突了。

  既然问题出现了,就需要解决。

  在 Java 中有一个非常实用的技术——package,它将逻辑上相关的代码组织在一起使用“包”来进行管理,这相当于文件系统中的文件夹。在文件系统中,文件夹内是相对独立的一个空间,不用担心一个文件夹和另一个文件夹中文件命名的冲突。在“包”中也一样,可以解决文件命名冲突问题,如果要在包外部再使用到包内的资源,直接通过 import 导入相关的 package 即可。类似包这样的概念,在其它的语言(如 C#)中也称为命名空间。

  JavaScript 中并没有提供原生的包或命名空间的支持,但可以使用其它的方法(如对象、闭包)来实现类似的效果。

  参照 Java 的方式,我使用 JavaScript 中的对象来简单修改 tools.js 文件:

  var Util = {

  css : function(element, attr) {

  // ...

  },

  offset : function(element) {

  // ...

  }

  };

  这样,当引入 tools.js 文件后,要获取 CSS 样式或获取元素的文档坐标,就通过类似 Util.css()/Util.offset() 的方法来实现。css 与 offset 的作用域是在对象 Util 下,再全局或是新对象中定义 css 属性是不受影响的。

  Util 这个名称也具有通用性,通常用作辅助工具定义的时候会使用到这个名称,为了体现该名称的唯一性,可以继续借鉴 Java 中 package 的命名规范(域名倒置):

  var com = {};

  com.GitHub = {};

  com.github.itrainhub = {};

  com.github.itrainhub.Util = {

  css : function(element, attr) {

  // ...

  },

  offset : function(element) {

  // ...

  }

  };

  要获取 CSS 样式值,则可使用 com.github.itrainhub.Util.css() 方法。但这样的写法增加了记忆难度,YUI 中关于这一点有比较好的解决方案,先按下暂且不表。

  使用对象的写法可解决命名冲突问题,但这种写法也会暴露对象的所有成员,使对象内部状态可以在对象外部被改写。比如在对象内部存在计数器:

  var Util = {

  _count : 0

  }

  在对象外部可以通过 Util._count = 18; 修改该计数器的值,这是不安全的。

  像计数器这样的变量,通常可能是作为对象的私有成员存在,不希望在对象外部还能继续修改其值,这时,可以使用 IIFE(立即执行函数)来设计:

  var Util = (function(){

  var _count = 0;

  function _css(element, attr) {

  // ...

  }

  function _offset(element) {

  // ...

  }

  return {

  css : _css,

  offset : _offset

  }

  })();

  这样,在外部就不能再直接修改 _count 的值了。

  通过命名空间,的确可以解决命名冲突的问题,我们可以暂时松一口气了。

  2. 文件依赖

  接着 tools.js 继续开发。

  在 tools.js 的基础上,可以开发出一些 UI 层通用的组件,如放大镜、轮播图之类的,这样各个项目中要使用这些功能的时候就不用重复造轮子了。

  通常情况下,每个 UI 组件都是以独立的 js 文件存在的,比如放大镜,可以将它放到一个 zoom.js 的文件中,当要使用到放大镜组件时,通过 引入即可。

  但很多时候,在使用 zoom.js 之前忘记了引入 tools.js,则使用 zoom.js 就会报错,无法保证它的正常执行。

  zoom.js 的正常执行依赖于 tools.js 的使用,上述的问题都还是比较容易解决的,但随着团队越来越大,业务需求越来越复杂,项目中组件间的依赖关系也会变得越来越复杂。比如:

  某一天,我扩充了 zoom.js 组件的功能,但除了使用到 tools.js 外,还使用到另一个工具 js 组件:helper.js。如果项目中已有 N 个地方之前使用到了 zoom.js 组件,我就只好全局搜索每个引用 zoom.js 的地方,再加上对 helper.js 的引用。

  再想想,随着项目推进,我们会继续修改 tools.js,添加更多的组件 component_1.js、component_2.js……某些组件中只使用到 tools.js,某些只使用到 helper.js,而某些组件既使用到了 tools.js 又使用到了 helper.js。那么关于组件间依赖关系的维护,工作量可想而知,如果以人肉的方式来保证依赖关系的维护,简直就要崩溃掉了。

  为什么维护组件间的依赖关系这么费神呢,因为 JavaScript 中天生缺少了引入其它 js 文件的语法。在 Java 中可以通过 import 引入依赖组件,在 CSS 中也有 @import 命令去引入其它的 CSS 文件,而 js 中却不能自动管理依赖。

  除了文件间的依赖关系维护不便外,如果在页面中引入的组件非常多,我们还得保证引用组件的路径及先后顺序不能出错,一旦出错,又得花时间查找错误,可想而知工作量是很可观了,再加上组件引入过多,又是以同步的方式加载各组件,也可能导致浏览器假死的现象。

  要解决这些问题,模块化开发的价值就体现出来了。

  3. 模块化开发

  3.1 模块化

  所谓模块化,就是把一个相对独立的功能,单独形成一个文件,可输入指定依赖、输出指定的函数,供外界调用,其它都在内部隐藏实现细节。这样即可方便不同的项目重复使用,也不会对项目造成额外的影响。

  前端使用模块化载发主要的作用是:

  • 异步加载 js,避免浏览器假死

  • 管理模块间依赖关系,便于模块的维护

  有了模块,我们就可以更方便地使用别人的代码,想要什么功能,就加载什么模块。

  但要使用模块的前提,是必然要形成可遵循的开发规范,使得开发者和使用者都有据可寻,否则你有你的写法,我有我的写法,大家没办法统一,也就不能很好的互用了。

  目前通用的规范是,服务器端使用 CommonJS 规范,客户端使用 AMD/CMD 规范。

  3.2 CommonJS

  CommonJS 规范出现是在 2009 年,node.js 就是该规范的实现。CommonJS 规范中是这样加载模块的:

  var gulp = require("gulp");

  gulp.task();

  模块的加载是同步的,这种写法适合服务器端,因为在服务器读取的模块都是在本地磁盘,加载速度很快,可同步加载完成。但是如果在客户端浏览器中,因为模块是放在服务器端的,模块加载取决于网络环境,以同步的方式加载模块时有可能出现“假死”状况。

  今天我主要介绍针对浏览器编程,不针对 node.js 内容,所以在此关于 CommonJS 规范就不作深究,知道 require() 用于加载模块即可。

  3.3 AMD

  由于在浏览器端,模块使用同步方式加载可能出现假死,那么我们采用异步加载的方式来实现模块加载,这就诞生了 AMD 的规范。

  AMD 即 Asynchronous Module Definition 的简称,表示“异步模块定义”的意思。AMD 规范:https://github.com/amdjs/amdjs-api/wiki/AMD。

  AMD 采用异步方式加载模块,模块的加载不影响它后面语句的运行。所有依赖所加载模块的语句,都被定义在一个回调函数中,等到模块加载完毕后,回调函数才会执行。

  AMD 也采用 require() 来加载模块,语法结构为:

  require([module], callback);

  module 是数组参数,表示所加载模块的名称;callback 是回调函数参数,所有模块加载完毕后执行该回调函数。如:

  require(["Jquery"], function($){

  $("#box").text("test");

  });

  3.4 CMD

  CMD 即 Common Module Definition 的简称,表示“通用模块定义”的意思。CMD 规范:Https://github.com/cmdjs/specification/blob/master/draft/module.md。

  CMD 规范明确了模块的基本书写格式和基本交互规则,该规范是在国内发展出来的,由玉伯在推广 SeaJS 过程中规范产出的。

  SeaJS 实现了 CMD 规范。SeaJS 要解决的问题和 RequireJS 一样,只不过在模块定义方式和模块加载(运行、解析)时机上有所不同。

  3.5 AMD 与 CMD 的区别

  AMD 是 RequireJS 在推广过程中对模块定义的规范化产出。

  CMD 是 SeaJS 在推广过程中对模块定义的规范化产出。

  二者主要区别如下:

  1 对于依赖的模块,AMD 是提前执行,CMD 是延迟执行。

  2 CMD 推崇依赖就近,AMD 推崇依赖前置。

  3 AMD 的 API 默认是一个当多个用,CMD 的 API 严格区分,推崇职责单一。

  当然还有一些其它细节上的区别,具体看规范的定义就好。

到此,关于“分析web前端模块化开发”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 分析web前端模块化开发

本文链接: https://www.lsjlt.com/news/85592.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 分析web前端模块化开发
    这篇文章主要介绍“分析web前端模块化开发”,在日常操作中,相信很多人在分析web前端模块化开发问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析web前端模块化开发”的疑惑...
    99+
    2022-10-19
  • 分析web前端模块化
    这篇文章主要介绍“分析web前端模块化”,在日常操作中,相信很多人在分析web前端模块化问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析web前端模块化”的疑惑有所帮助!接...
    99+
    2022-10-19
  • 前端es6是不是模块化开发
    这篇文章主要介绍“前端es6是不是模块化开发”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“前端es6是不是模块化开发”文章能帮助大家解决问题。 ...
    99+
    2022-10-19
  • web前端开发规范的示例分析
    小编给大家分享一下web前端开发规范的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!规范说明此为前端开发团队遵循和约定的...
    99+
    2022-10-19
  • 分析web前端开发中跨域问题
    本篇内容介绍了“分析web前端开发中跨域问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么同源策略同源...
    99+
    2022-10-19
  • JS前端模块化规范的示例分析
    这篇文章将为大家详细讲解有关JS前端模块化规范的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Script 标签其实最原始的 JavaScript 文件加载方式,...
    99+
    2022-10-19
  • 组件化的前端开发流程分析
    这篇文章将为大家详细讲解有关组件化的前端开发流程分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。背景 做前端的同学都知道,做的页面多了,东西就会乱,因此我们需要统一一个开发流程。开发流程的好坏,直接影响...
    99+
    2023-06-08
  • web前端开发中的while循环实例分析
    今天给大家介绍一下web前端开发中的while循环实例分析。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。while循环while(循环终止条件){}案例&nb...
    99+
    2023-06-05
  • drupal模块开发分析
    drupal模块开发常见问题: 1、一般的模块分析方法:安装后先分析menu 根据menu查询函数,menu的类型大概分为: menu_default_local_task()默认显示tab menu_local_tas...
    99+
    2022-06-12
    drupal 模块开发
  • Node.js的模块化开发实例分析
    这篇文章主要讲解了“Node.js的模块化开发实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Node.js的模块化开发实例分析”吧!1.Node.j...
    99+
    2022-10-19
  • Web前端开发css基础样式的示例分析
    小编给大家分享一下Web前端开发css基础样式的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!颜色和单位的使用 颜色用颜...
    99+
    2022-10-19
  • web前端外观模式的示例分析
    这篇文章给大家分享的是有关web前端外观模式的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。外观模式(Facade Pattern)外观模式是最常见的设计模式之一,它为子...
    99+
    2022-10-19
  • web前端中策略模式的示例分析
    这篇文章将为大家详细讲解有关web前端中策略模式的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。策略模式(Strategy Pattern)策略模式简单描述就是:...
    99+
    2022-10-19
  • web前端中单例模式的示例分析
    小编给大家分享一下web前端中单例模式的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!单例模式(Singleton Pa...
    99+
    2022-10-19
  • web前端中工厂模式的示例分析
    这篇文章主要介绍了web前端中工厂模式的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。工厂模式(Factory Pattern)工厂...
    99+
    2022-10-19
  • web前端中代理模式的示例分析
    这篇文章主要为大家展示了“web前端中代理模式的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“web前端中代理模式的示例分析”这篇文章吧。代理模式(Pr...
    99+
    2022-10-19
  • 浅析web前端开发者的招聘要求
    随着互联网的不断发展,Web前端开发成为了非常重要的职业之一。Web前端开发人员主要负责开发网站的前端部分,包括页面设计、交互效果实现、数据展示等方面。前端开发人员的职责非常广泛,需要掌握多种编程语言和工具,同时具备创新、学习能力和团队协作...
    99+
    2023-05-14
  • Vue.js高效前端开发源码分析
    这篇“Vue.js高效前端开发源码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue.js高效前端开发源码分析”文章吧...
    99+
    2023-07-05
  • Android开发之项目模块化的示例分析
    这篇文章主要为大家展示了“Android开发之项目模块化的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android开发之项目模块化的示例分析”这篇文章吧。项目协同项目协同,也叫多项目...
    99+
    2023-05-30
    android
  • 以Java Web项目为例浅谈前后端分离开发模式
    目录为什么要前后端分离?什么是前后端分离?前后端分离的优缺点?对于你们的团队和产品有没有必要前后端分离?为什么要前后端分离? 以Java Web项目为例,在传统的开发模式中,前端代码...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作