`

Cocos2d-JS中JavaScript继承

阅读更多

JavaScript语言本身没有提供类,没有其它语言的类继承机制,它的继承是通过对象的原型实现的,但这不能满足Cocos2d-JS引擎的要求。由于Cocos2d-JS引擎是从Cocos2d-x演变而来的,在Cocos2d-JS的早期版本Cocos2d-HTML中几乎全部的API都是模拟Cocos2d-x API而设计的,Cocos2d-x本身是有C++编写的,其中的很多对象和函数比较复杂,JavaScript语言描述起来有些力不从心了。
在开源社区中John Resiq在他的博客(http://ejohn.org/blog/simple-javascript-inheritance/)中提供了一种简单JavaScript继承(Simple JavaScript Inheritance)方法。
John Resiq的简单JavaScript继承方法灵感来源于原型继承机制,它具有与Java等面向对象一样的类概念,并且他设计了所有类的根类Class,它的代码如下:

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. /* Simple JavaScript Inheritance  
  2.  * By John Resig http://ejohn.org/  
  3.  * MIT Licensed.  
  4.  */  
  5. // Inspired by base2 and Prototype  
  6. (function(){  
  7.   var initializing = falsefnTest = /xyz/.test(function(){xyz;}) ? /\b_super\b/ : /.*/;  
  8.    
  9.   // The base Class implementation (does nothing)  
  10.   this.Class = function(){};  
  11.    
  12.   // Create a new Class that inherits from this class  
  13.   Class.extend = function(prop) {  
  14.     var _super = this.prototype;  
  15.      
  16.     // Instantiate a base class (but only create the instance,  
  17.     // don't run the init constructor)  
  18.     initializing = true;  
  19.     var prototype = new this();  
  20.     initializing = false;  
  21.      
  22.     // Copy the properties over onto the new prototype  
  23.     for (var name in prop) {  
  24.       // Check if we're overwriting an existing function  
  25.       prototype[name] = typeof prop[name] == "function" &&  
  26.         typeof _super[name] == "function" && fnTest.test(prop[name]) ?  
  27.         (function(name, fn){  
  28.           return function() {  
  29.             var tmp = this._super;  
  30.              
  31.             // Add a new ._super() method that is the same method  
  32.             // but on the super-class  
  33.             this._super = _super[name];  
  34.              
  35.             // The method only need to be bound temporarily, so we  
  36.             // remove it when we're done executing  
  37.             var ret = fn.apply(this, arguments);          
  38.             this._super = tmp;  
  39.              
  40.             return ret;  
  41.           };  
  42.         })(name, prop[name]) :  
  43.         prop[name];  
  44.     }  
  45.      
  46.     // The dummy class constructor  
  47.     function Class() {  
  48.       // All construction is actually done in the init method  
  49.       if ( !initializing && this.init )  
  50.         this.init.apply(this, arguments);  
  51.     }  
  52.      
  53.     // Populate our constructed prototype object  
  54.     Class.prototype = prototype;  
  55.      
  56.     // Enforce the constructor to be what we expect  
  57.     Class.prototype.constructor = Class;  
  58.    
  59.     // And make this class extendable  
  60.     Class.extend = arguments.callee;  
  61.      
  62.     return Class;  
  63.   };  
  64. })();  



与Java中的Object一样所有类都直接或间接继承于Class,下面是继承Class实例:

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. var Person = Class.extend({                                             ①  
  2.     init: function (isDancing) {                                                ②  
  3.         this.dancing = isDancing;  
  4.     },  
  5.     dance: function () {                                                    ③  
  6.         return this.dancing;  
  7.     }  
  8. });  
  9.   
  10.   
  11. var Ninja = Person.extend({                                             ④  
  12.     init: function () {                                                     ⑤  
  13.         this._super(false);                                             ⑥  
  14.     },  
  15.     dance: function () {                                                    ⑦  
  16.         // Call the inherited version of dance()  
  17.         return this._super();                                               ⑧  
  18.     },  
  19.     swingSword: function () {                                               ⑨  
  20.         return true;  
  21.     }  
  22. });  
  23.   
  24.   
  25. var p = new Person(true);                                               ⑩  
  26. console.log(p.dance());// true                                              ⑪  
  27.   
  28.   
  29. var n = new Ninja();                                                        ⑫  
  30. console.log(n.dance()); // false                                                ⑬  
  31. console.log(n.swingSword()); // true      



如果你对于Java语言的面向对象很熟悉的话,应该很容易看懂。其中第①行代码是声明Person类,它继承自Class,Class.extend()表示继承自Class。第②行代码的定义构造函数init,它的作用是初始化属性。第③行代码是定义普通函数dance(),它可以返回属性dancing。
第④行代码是声明Ninja类继承自Person类,第⑤行代码的定义构造函数init,在该函数中this._super(false)语句是调用父类构造函数初始化父类中的属性,见代码第⑥行所示。第⑦行代码是重写dance()函数,它会覆盖父类的dance()函数。第⑧行代码是this._super()是调用父类的dance()函数。第⑨行代码是子类Ninja新添加的函数swingSword()。
第⑩行代码通过Person类创建p对象,给构造函数的参数是true。第⑪行代码是打印日志p对象dance属性,结果为true。
第⑫行代码通过Ninja类创建n对象,构造函数的参数为空,默认初始化采用false初始化父类中的dance属性。因此在代码第⑬行打印为false。

这种简单JavaScript继承方法事实上实现了一般意义上的面向对象概念的继承和多态机制。这种简单JavaScript继承方法是Cocos2d-JS继承机制的核心,Cocos2d-JS稍微做了修改,熟悉简单JavaScript继承的用法对于理解和学习Cocos2d-JS非常的重要。

 

 

更多内容请关注最新Cocos图书《Cocos2d-x实战:JS卷——Cocos2d-JS开发
本书交流讨论网站:http://www.cocoagame.net
欢迎加入Cocos2d-x技术讨论群:257760386
更多精彩视频课程请关注智捷课堂Cocos课程:http://v.51work6.com

 

 

 

《Cocos2d-x实战 JS卷》现已上线,各大商店均已开售:

京东:http://item.jd.com/11659698.html

欢迎关注智捷iOS课堂微信公共平台,了解最新技术文章、图书、教程信息

 

分享到:
评论

相关推荐

    Cocos2d-JS开发之旅

    6. **脚本编程**:深入讲解JavaScript在Cocos2d-JS中的应用,包括对象模型、类继承和模块化开发。 7. **性能优化**:提供性能调优的技巧和最佳实践,确保游戏在各种设备上流畅运行。 8. **发布与打包**:指导如何将...

    cocos2d-html.min.zip

    cocos2d-js是一个基于Cocos2d-x的JavaScript版本,它继承了Cocos2d-x的丰富功能,包括精灵、动作、层、场景、物理引擎等,同时支持HTML5和JavaScript,使得游戏能在浏览器上运行。而“cocos2d-html.min”则特指这个...

    cocos2d-x-3.13.1.zip

    cocos2d-x 是基于cocos2d-xna的一个C++实现,它继承了cocos2d的优秀特性,并且引入了C++语言,提高了代码的可读性和可维护性。这个框架提供了一整套游戏开发工具,包括场景管理、精灵、动画、物理引擎、粒子系统、...

    cocos2d-x-2.2.2 中文帮助文档

    cocos2d-x是一个开源的、跨平台的2D游戏开发框架,基于C++,并支持多种编程语言如Lua和JavaScript。此中文文档的生成,是为了方便中国开发者能够更加便捷地学习和使用这一强大的开发工具。 1. **框架介绍**:cocos...

    结合cocos2d-js3.0结合cocos studio实现时钟倒计时功能

    在本文中,我们将深入探讨如何使用Cocos2d-js 3.0框架结合Cocos Studio来实现一个时钟倒计时功能。Cocos2d-js是Cocos2d-x的一个分支,它允许开发者使用JavaScript编写游戏和应用,而Cocos Studio则是一个强大的可视...

    Cocos2d-X游戏【泰然网《跑酷》】JS到C++移植

    在Cocos2d-X中,C++代码通常使用面向对象的设计模式,例如继承自Node或Component等基类。 2. **Cocos2d-X C++ API**:熟悉并使用Cocos2d-X的C++ API至关重要。这包括精灵(Sprite)、场景(Scene)、动作(Action)...

    Cocos2d-x教程

    - **定义与特点**:Cocos2d-x是一款高性能的2D游戏开发框架,最初基于Cocos2d-iPhone开发而来,继承了其易用性、高效性和灵活性等特点。 - **跨平台能力**:具备强大的跨平台特性,允许开发者只需编写一次代码即可...

    cocos2d-android-1资源:API文档

    Cocos2d基于Python,但也有多个语言版本,如cocos2d-x支持C++,cocos2d-js支持JavaScript,以及cocos2d-java针对Android平台。它提供了丰富的功能,包括场景管理、动作与特效、物理引擎、精灵与图块地图、触摸事件...

    Cocos2d-x 2048

    此外,Cocos2d-x支持lua和JavaScript两种脚本语言,但这里提到的是cpp文件,表明我们将使用C++进行开发。 2048游戏的核心算法是基于二维数组的矩阵操作。在游戏开始时,数组中有两个随机位置的数字2。玩家可以通过...

    cocos2d-x-3.6离线文档

    在cocos2d-x的离线文档中,类图的存在极大地帮助了开发者理解框架的架构和各个类的功能。通过类图,开发者可以直观地看到各个类的层次结构,更好地把握框架的设计思想,从而更高效地进行代码编写。 cocos2d-x 3.6...

    Cocos2d-x高级开发教程.pdf

    Cocos2d-x继承了Cocos2d系列的核心优势,如易用性、高效性和灵活性。它不仅保留了这些特点,还具备强大的跨平台能力,能够在iOS、Android、Windows、OSX等主流游戏平台上无缝部署。跨平台开发是移动游戏开发的趋势,...

    兄弟连cocos2d-x3.0 final视频教程完整版

    Cocos2d-x是一款开源的游戏开发框架,它支持多种编程语言,包括C++、JavaScript和Lua等。该框架特别适用于移动平台游戏的开发,支持iOS、Android等多个平台。Cocos2d-x以其强大的功能、高效的性能以及跨平台的优势,...

    Cocos2d-x手游-雷电战机加强版源码下载.zip

    Cocos2d-x是一款跨平台的游戏开发框架,广泛应用于2D游戏的开发,它基于C++,支持多种编程语言,包括Lua和JavaScript。本篇文章将深入探讨“雷电战机加强版”这款手游的源码,旨在帮助开发者理解Cocos2d-x在实际项目...

    Cocos2D-3.x 游戏开发齐全教程、文档

    在2013年,Cocos2D分裂成为两个主要分支:Cocos2D-iPhone和Cocos2D-JavaScript。随后,Cocos2D-iPhone分支又分为Cocos2D和Cocos2D-X。而Cocos2D-X是一个开源的游戏引擎,支持C++、Lua和JavaScript作为编程语言,并且...

    别踩白块游戏cocos2d-x3.x实现

    Cocos2d-x是一个广泛使用的开源游戏引擎,尤其适合2D游戏开发,它支持多种编程语言,包括C++、Lua和JavaScript。 首先,我们需要了解Cocos2d-x的基本架构。Cocos2d-x包含了一系列的类,如Scene(场景)、Layer(层...

    精选_基于Cocos2d-x实现的RunOrDie小游戏_源码打包

    游戏中的角色、障碍物等可以视为游戏对象,它们在Cocos2d-x中表现为继承自`Sprite`的类。开发者可以通过`SpriteBatchNode`优化渲染性能,将多个精灵绘制在同一个批次中。实体对象往往有额外的属性(如生命值、速度)...

    Cocos2D-X开发学习笔记-渲染框架之布景层类的使用示例

    Cocos2D-X是一款流行的开源游戏开发框架,尤其在2D游戏领域中广泛应用。它基于C++,同时提供了Lua和JavaScript的绑定,让开发者可以选择不同的编程语言进行游戏开发。本篇学习笔记主要聚焦于Cocos2D-X的渲染框架,...

    cocos2d-x 坚持20秒

    开发者需要创建一个自定义的场景类,继承自`cocos2d::Scene`,并在此类中实现游戏逻辑。 2. **精灵(Sprite)**:精灵是游戏中可移动或交互的对象,如主角和障碍物。在cocos2d-x中,我们可以使用`cocos2d::Sprite`...

Global site tag (gtag.js) - Google Analytics