Skip to main content

JavaScript - An Example for Inheritance

Everyone of us know, Inheritance is a way to acquire properties and methods of another object. In other words it is a way to establish is-a relationship between two objects. The static languages by default provide some easier ways to achieve this. For an example, we have "extend" keyword in Java for extending other object.

JavaScript is protypal inheritance language (class-free) means that objects can inherit properties from other objects. Let's see an example.

Let's create a parent class for Animal

 * Animal - Constructor and parent class for all animals.
 * @param {Object} aType - Type of the animal
 * @param {Object} aName - Name of the animal 

function Animal(aType, aName) {
 this.type = aType; = aName;
} = function() {
 console.log('All animal will eat');

We have to do following steps for extending animal class.

1. Calling super class constructor from child class constructor.
2. Setting up prototype chain.
3. Adding methods to child class.

Let's create child class and extending Animal class by following above steps.

 * Bird - Constructor and child class of Animal.
 * @param {Object} aType - Type of the animal
 * @param {Object} aName - Name of the animal 

function Bird(aType, aName, bType) {
 //Calling super class constructor, aType, aName);
 this.birdType = bType;
//Setup the protype chain
Bird.prototype = new Animal();
//Set the constructor attribute to Bird
Bird.prototype.constructor = Bird;

//Add methods to Bird class. = function() {
 console.log('I am flying');

Let's create an object for Bird and try to access methods and properties of the parent class.

bird = new Bird('Ducks', 'Tundra Swan', 'Ducks');; //Calling super class method; //Calling child class method

Final result of the application is given below.

All modern library like jQuery and Ext JS has provided simple utility function for extending other class something like that.

var Pointer = Pointer || {};
 * Simple utility function for extend.
Pointer.extend = function(subClass, superClass) {
 var F = function() {};
 F.prototype = superClass.prototype;
 subClass.prototype = new F(); 
 subClass.prototype.constructor = subClass;
 subClass.superclass = superClass.prototype;
  * The below condition is important for handling
  * extend(Person, Object); //Person - Sample class extending JavaScript Object class.
 if(superClass.prototype.constructor === Object.prototype.constructor) {
  superClass.prototype.constructor = superClass;

Simple another example using above extend function.
 * This is parent class constructor
 * @param {Object} name
var Person = function(name) {, name); = name;

Pointer.extend(Person, Object); //Person is extending Object class.

Person.prototype.getName = function() {

 * This is child class of the Person.
 * @param {Object} name
 * @param {Object} profession
var Author = function(name, profession) {
 //, name);, name);
 this.profession = profession;

Pointer.extend(Author, Person);

Author.prototype.getProfession = function() {
 return this.profession;

For testing, let's create some objects.

person1 = new Author('Suriya', 'Solution Developer');
person2 = new Person('Hilar');

The result of the above example is should be something like this.


ziobkd7q73 said…
With a dedication to innovation, we manufacture and assemble essential air- and spacecraft parts with rugged energy, superior precision, tight tolerances, and quality supplies. The CNC Machining Program prepares college students for a high-demand, entry-level position as a CNC machine operator or general machinist. CNC operators work in a variety of|quite so much of|a wide selection of} manufacturing environments and are trained to program, set-up, and operate a computer numerical control Men’s Open Toe Slippers machine, inspect components, carry out production runs and set-up jobs. Al Youngwerth is the CEO and founder of VersaBuilt Robotics Inc., headquartered in Boise, Idaho. VersaBuilt is a obotics technology firm providing patented automated CNC technology and solutions to producers worldwide.

Popular posts from this blog

Ext JS 4 – Creating web page using Ext.container.Viewport class and region propery

The Ext.container.Viewport is used for creating general web page and region property is used for splitting web page into different parts. Ext.container.Viewport is a specialized container represents the viewable area of the application (the browser area). It render itself to the document body, there is no need for providing renderTo property and it automatically sizes itself to size of the browser viewport. The viewport also re-size the child elements based on view area(based on browser width and height). The default layout of the viewport is border layout and we can customize this property according to our requirements. The viewport does not provide any scrolling. If necessary, the child elements(generally panels) within viewport needs to provide a scroll feature by using autoScroll property. See the below example for better understanding. This is Home.js file placed into app/view folder. Ext.define('MyApp.view.Home', { extend : 'Ext.container.Viewport&#

Getting key/value pair from JSON object and getting variable name and value from JavaScript object.

 Hi, I had faced one issue like this. I have an JSON object but I don't know any key name but I need to get the all the key and corresponding value from JSON object using client side JavaScript. Suddenly I wondered whether it's possible or not, after that I had done lot of workaround and finally got this solution. See the below example.    function getKeyValueFromJSON() {     var jsonObj =  {a:10,b:20,c:30,d:50} ;     for ( var key in jsonObj) {       alert( "Key: " + key + " value: " + jsonObj[key]);     }  }  In this example I have created the one json array as string, and converted this string into JSON object using eval() function. Using for-each loop I got all the key value from jsonObj, and finally using that key I got the corresponding value.  Finally I got the alert like this,    Key: a value:10    Key: b value:20    Key: c value:30    Key: d value:50  During this workaround I got one more idea, using this same way I got

Simple Login Application Using Spring MVC and Hibernate – Part 1

 I hope developers working in web application development might hear about MVC architecture. Almost all technologies provide support for MVC based web application development, but the success is based on many factors like reusable of the code, maintenance of the code, future adaption of the code, etc..,  The success of the Spring MVC is “ Open for extension and closed for modification ” principle. Using Spring MVC the developers can easily develop MVC based web application. We don’t need any steep learning curve at the same time we need to know the basics of spring framework and MVC architecture. The Spring MVC consists of following important components. 1. Dispatcher servlet 2. Controller 3. View Resolver 4. Model Spring MVC - Overview  The overall architecture of Spring MVC is shown here.  1. When “Dispatcher Servlet” gets any request from client, it finds the corresponding mapped controller for the request and just dispatches the request to the corresponding contro