javascript框架模块化的两种写法

在以下实例中,总模块为Garu,子模块为WorldRender
即:
Garu
| - World
| - Render


写法一:(对象形式)

框架部分:

var Garu = {};
Garu.val = "Garu"; // 总模块的变量
Garu.init = function(){ // 总模块的方法
  console.log("Garu init");
}

/*
  Garu.World
*/
Garu.World = {};
(function(){
  var World = Garu.World;
  World.val = "World"; // World子模块的变量
  World.init = function(){ // World子模块的方法
    console.log("Garu.World init");
  }
})();

/*
  Garu.Render
*/
Garu.Render = {};
(function(){
  var Render = Garu.Render;
  Render.val = "Render"; // Render子模块的变量
  Render.init = function(){ // Render子模块的方法
    console.log("Garu.Render init");
  }
})();

调用方式:

Garu.init(); // 调用总模块的方法
console.log(Garu.val); // 调用总模块的变量

var World = Garu.World;
World.init(); // 调用子模块的方法
console.log(World.val); // 调用子模块的变量

var Render = Garu.Render;
Render.init();
console.log(Render.val);

写法二:(类+原型链+对象形式)

框架部分:

var Garu = (function(){
  function Garu(){
    this.val = "garu"; // 总模块的变量
  }
  
  Garu.prototype.init = function(){ // 总模块方法
    console.log("Garu init");
  }
  
  var World = Garu.prototype.World = {};
  World.val = "World"; // World子模块的变量
  World.init = function(){ // World子模块的方法
    console.log("Garu.World init");    
  }
  
  var Render = Garu.prototype.Render = {};
  Render.val = "Render"; // Render子模块的变量
  Render.init = function(){ // Render子模块的方法
    console.log("Garu.Render init");    
  }
  
  return Garu;
})();

调用方式:

var Garu = new Garu();
Garu.init();
console.log(Garu.val);

var World = Garu.World;
World.init();
console.log(World.val);

var Render = Garu.Render;
Render.init();
console.log(Render.val);
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 178,789评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,506评论 19 139
  • 转自:[http://blog.csdn.net/liu88010988/article/details/5154...
    hackywit阅读 6,278评论 0 26
  • 春天 春天是清丽多情的少女。 忽如一夜春风来, 千树万树梨花开。 帘幕柳丝,是她 瀑泻的刘海。 嫩山幼水,是她新着...
    郑时光阅读 572评论 0 0
  • 因为被眼前的任务扰乱了日常。读书和记录被搁置,浑浑噩噩里,十日有余。时间是个无情地杀手,面对懒散与懈怠,...
    雪之意阅读 291评论 0 0

友情链接更多精彩内容