JavaScript Create Your Own Objects
Objects are useful to organize information.
 |
Try it Yourself - Examples |
Create a direct instance of an object
Create a template for an object
JavaScript Objects
Earlier in this tutorial we have seen that JavaScript has several built-in objects, like String, Date, Array, and more.
In addition to these built-in objects, you can also create your own.
An object is just a special kind of data, with a collection of properties and methods.
Let's illustrate with an example: A person is an object. Properties are the values associated with the object. The persons'
properties include name, height, weight, age, skin tone, eye color, etc. All persons have these properties, but the values of those properties will differ from
person to person. Objects also have methods. Methods are the actions that can be performed on objects. The persons' methods could be eat(), sleep(), work(), play(), etc.
Properties
The syntax for accessing a property of an object is:
You can add properties to an object by simply giving it a value. Assume that the personObj already exists -
you can give it properties named firstname, lastname, age, and eyecolor as follows:
personObj.firstname="John";
personObj.lastname="Doe";
personObj.age=30;
personObj.eyecolor="blue";
document.write(personObj.firstname); |
The code above will generate the following output:
Methods
An object can also contain methods.
You can call a method with the following syntax:
Note: Parameters required for the method can be passed between the parentheses.
To call a method called sleep() for the personObj:
Creating Your Own Objects
There are different ways to create a new object:
1. Create a direct instance of an object
The following code creates an instance of an object and adds four properties to it:
personObj=new Object();
personObj.firstname="John";
personObj.lastname="Doe";
personObj.age=50;
personObj.eyecolor="blue"; |
Adding a method to the personObj is also simple. The following code adds a method called eat() to the personObj:
2. Create a template of an object
The template defines the structure of an object:
function person(firstname,lastname,age,eyecolor)
{
this.firstname=firstname;
this.lastname=lastname;
this.age=age;
this.eyecolor=eyecolor;
} |
Notice that the template is just a function. Inside the function you need to
assign things to this.propertyName. The reason for all the "this" stuff is that you're going
to have more than one person at a time (which person you're dealing with must be
clear). That's what "this" is: the instance of the object at hand.
Once you have the template, you can create new instances of the object, like this:
|
myFather=new person("John","Doe",50,"blue");
myMother=new person("Sally","Rally",48,"green"); |
You can also add some methods to the person object. This is also done inside the template:
function person(firstname,lastname,age,eyecolor)
{
this.firstname=firstname;
this.lastname=lastname;
this.age=age;
this.eyecolor=eyecolor;
this.newlastname=newlastname;
} |
Note that methods are just functions attached to objects. Then we will have to write the newlastname() function:
function newlastname(new_lastname)
{
this.lastname=new_lastname;
} |
The newlastname() function defines the person's new last name and assigns that to the person. JavaScript knows which person you're
talking about by using "this.". So, now you can write: myMother.newlastname("Doe").
Make your web applications look like a million bucks
|
|
Most web applications today use boring methods to present data to their viewers using grids or simple HTML tables. FusionCharts induces "life" into the web applications by converting monotonous data into lively charts, gauges & maps.
FusionCharts works with all technologies like ASP, ASP.NET, PHP, ColdFusion, Ruby on Rails, JSP, HTML pages etc.
and connects to any database to render animated & interactive charts. It takes less than 15 minutes and no expertise
whatsoever to build your first chart and just a glance of it to captivate your audience. This fact is endorsed by our
12,000 customers and 150,000 users which include a majority of the Fortune 500 companies.
And yeah, your applications could look like a million bucks by spending just $69.
So go ahead, download your
copy of FusionCharts and start "wow-ing" your customers now!
|
 |
W3Schools' Online Certification Program
The perfect solution for professionals who need to balance work, family, and career building.
More than 4000 certificates already issued!
|
The HTML Certificate documents your knowledge of HTML, XHTML, and CSS.
The JavaScript Certificate documents your knowledge of JavaScript and HTML DOM.
The XML Certificate documents your knowledge of XML, XML DOM and XSLT.
The ASP Certificate documents your knowledge of ASP, SQL, and ADO.
The PHP Certificate documents your knowledge of PHP and SQL (MySQL).
|