首页 技术 正文
技术 2022年11月17日
0 收藏 513 点赞 4,138 浏览 944 个字

模块化开发

概述

什么是模块化开发

  • 将软件产品看作为一系列功能模块的组合

  • 通过特定的方式实现软件所需模块的划分、管理、加载

为什么使用模块化开发

实现模块化的推演

step-01 全局函数

step-02 封装对象

step-03 划分私有空间

step-04 模块的扩展与维护

step-05 第三方依赖管理

在什么场景下使用模块化开发 业务复杂 重用逻辑非常多 扩展性要求较高


实现规范

CommonJS规范

AMD规范

CMD规范


实现

Seajs

使用步骤

  1. 在页面中引入sea.js文件

  2. 定义一个主模块文件,比如:main.js

  3. 在主模块文件中通过define的方式定义一个模块,并导出公共成员

  4. 在页面的行内脚本中通过seajs.use(‘path’,fn)的方式使用模块

  5. 回调函数的参数传过来的就是模块中导出的成员对象

定义一个模块

  • define

define(function(require, exports, module) {
 exports.add = function(a, b) {
   return a + b;
};
});

使用一个模块

  • seajs.use

    • 一般用于入口模块

    • 一般只会使用一次

  • require

    • 模块与模块之间

导出成员的方式

  • module.exports

  • exports.xxx

  • return

  • 三种方式的优先级

异步加载模块

  • 默认require的效果是同步的,会阻塞代码的执行,造成界面卡顿

  • require.async();

require.async('path',function(module) {

});

使用第三方依赖(jQuery)

  • 由于CMD是国产货,jquery默认不支持

  • 改造

// 适配CMD
if (typeof define === "function" && !define.amd) {
 // 当前有define函数,并且不是AMD的情况
 // jquery在新版本中如果使用AMD或CMD方式,不会去往全局挂载jquery对象
 define(function() {
   return jQuery.noConflict(true);
});
}

Seajs配置

  • 配置

  • seajs.config

    • base

    • alias

使用案例

  • Tab标签页

Require

angular之模块开发一

angular之模块开发一

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,076
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,552
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,400
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,176
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,812
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,894