spacer
Yehuda Shiran March 19, 2001
Accessing Globals from an Object
Tips: March 2001

Yehuda Shiran, Ph.D.
Doc JavaScript

Developer News
News Flash: Adobe Has iPhone Workaround
Adobe's Flash 10.1 Goes Mobile (Minus iPhone)
A Salute to Visionary CEOs

There are at least three different ways to define a function in JavaScript. They are all equivalent in their way of treating global variables. They can modify global variables from the outside context. This statement is no longer true when you define an object's methods. We initialize a global variable to 5, and each function definition below adds 10 to it inside the function definition. The traditional and anonymous definitions do modify the global variable, but the constructor definition does not. In fact, you get an error message when trying to access a global variable from inside the constructor definition. Notice that each click below will increment the global variable by 10. Here are the class and object definitions, line-wrapped here for better readability on this page:

function myGlobal() {
  var global = 5;
  function first(param) {
    global += 10;
    alert(param + " method shows global to be " + global);
  }
  this.first = first;
  this.second = function(param) 
   {global += 10; 
    alert(param + " method shows global to be " + global)};

  this.third = new Function(
   "param", 
   " global += 10; alert(param + ' method shows global to be ' + global)");
}
var x = new myGlobal();

Let's try calling all methods: traditional, anonymous, and constructor.


People who read this tip also read these tips:

Look for similar tips by subject:

internet.commediabistro.comJusttechjobs.comGraphics.com

Search:

WebMediaBrands Corporate Info

Legal Notices, Licensing, Reprints, Permissions, Privacy Policy.
Advertise | Newsletters | Shopping | E-mail Offers | Freelance Jobs

webref The latest from WebReference.com Browse >
Building a Banking Application Home Page with OOP · Mixing Scripting Languages · Review: phpFox, a Social Networking CMS with all the Bells and Whistles
Sitemap · Experts · Tools · Services · Email a Colleague · Contact FREE Newsletters 
 The latest from internet.com
Enterprise 2.0: Social Networking in the Cloud · BroadSoft Marketplace Hastens Pace of Telephony Innovation · Review: HTC Hero for Sprint