理解JavaScript中的对象

时间:2021-01-17 14:48:57

    JavaScript有一种object数据类型,但是这种对象不同于c#或vb中的对象,在c#中,我们通过类创建一个对象,一个类相当于创建对象的模板,定义了对象的属性和方法,这些对象和方法将永远固定,我们不能在运行时不能增加对象的属性和方法。
    在JavaScript没有类的定义,创建对象时没有固定的模板,可以动态的创建新的属性和方法,在动态创建新属性的时候,我们能做的就是为这个属性创建新的值,下面一个例子就是创建一个对象并增加x,y两个属性。

理解JavaScript中的对象var  Programmer  =   new  Object();
理解JavaScript中的对象Programmer.name 
=   " Young " ;
理解JavaScript中的对象Programmer.age 
=   25 ;
理解JavaScript中的对象alert(Programmer.name 
+   "  :  "   +  Programmer.age);

    JavaScript对象完全不同于c#或vb对象,JavaScript对象可以看成一组健/值对的集合,用对象.属性名来访问一个对象属性。我们可以把JavaScript对象看成.NET framework中Dictionary类,我们可以通过"[]"操作符来创建对象属性。

理解JavaScript中的对象var  Programmer  =   new  Object();
理解JavaScript中的对象Programmer[
" name " =   " Young " ;
理解JavaScript中的对象Programmer[
" age " ] =   25 ;
理解JavaScript中的对象document.getElementById(
" message " ).innerHTML = Programmer[ " name " +   "  :  "   +  Programmer[ " age " ];
理解JavaScript中的对象alert(Programmer.name 
+   "  :  "   +  Programmer.age);
     通过上面的例子可以发现两种访问对象的方法是一样的。如果一个属性没有创建,将返回"undefined"。
我们同样可以将函数添加为健/值对集合的值,这样就构建为对象的方法,
理解JavaScript中的对象var  Programmer  =   new  Object();
理解JavaScript中的对象Programmer[
" name " =   " Young " ;
理解JavaScript中的对象Programmer.age
=   25 ;
理解JavaScript中的对象理解JavaScript中的对象Programmer.speak
= function () {
理解JavaScript中的对象                alert(
this.name + " : " + this["age"]);
理解JavaScript中的对象             }

理解JavaScript中的对象Programmer.speak();

     在上面的代码中我们交替使用"."和"[]"来定义可访问属性、方法,者=这两种方法的一样的,有时这些操作符会导致一些概念上的混淆,在为一个已经存在的属性设置新值是表达的不是很清晰,下面我们介绍第三种语法可以更加明确的表达我们的意图。

理解JavaScript中的对象var  Programmer  =  
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象     name : 
"Young",
理解JavaScript中的对象     age : 
25,
理解JavaScript中的对象理解JavaScript中的对象     speak : 
function(){ alert(this.name + " : " + this.age); }
理解JavaScript中的对象}

理解JavaScript中的对象Programmer.speak();
    上面的代码更加清晰的表达了对象初始化的开始和结束,我们还可以用这种方法在独享中嵌套对象。
理解JavaScript中的对象var  Programmer  =  
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象理解JavaScript中的对象     Figure : 
{name : "Young" , age : 25 },
理解JavaScript中的对象理解JavaScript中的对象     Company : 
{name : " Arcadia" , address : "ShenZheng"},
理解JavaScript中的对象理解JavaScript中的对象     speak : 
function()
理解JavaScript中的对象                alert(
"name:"+this.Figure.name+"\nage:"+this.Figure.age + "\nCompany:"+this.Company.name+" of 
理解JavaScript中的对象
理解JavaScript中的对象
"+this.Company.address); 
理解JavaScript中的对象            }

理解JavaScript中的对象}
;
理解JavaScript中的对象Programmer.speak();

     这种语法因为其清晰的意图和紧凑的代码格局而非常流行,你可以在各种流行的JavaScript frameworks中看到,包括目前在互联网上流行的JavaScript Object Notation(JSON),JSON是一种轻量级的数据交换格式,同时也易于机器解析和生成,语法也非常严格。JSON允许JavaScript在互联网上交换数据,我们可以用eval将JSON对象转化为本地JavaScript对象。

理解JavaScript中的对象var  Programmer = " ({name: 'Young',age : 25}) " ;
理解JavaScript中的对象
var  p  =  eval(Programmer);
理解JavaScript中的对象alert(p.name 
+  ','  +  p.age);
     通过上面的讨论我们知道了明白了所有的JavaScript对象都是一组字典。在JavaScript中还有另外一个重要的东西——函数。
1:在JavaScript中,函数都是一个对象。这一点完全不同于c#中的方法。我们看下面一个例子。
理解JavaScript中的对象function  add(point1, point2)
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象理解JavaScript中的对象     
var result = 
理解JavaScript中的对象        x : point1.x 
+ point2.x, 
理解JavaScript中的对象        y : point1.y 
+ point2.y
理解JavaScript中的对象     }
 
理解JavaScript中的对象     
return result; 
理解JavaScript中的对象}

理解JavaScript中的对象理解JavaScript中的对象
var  p1  =   { x: 1, y: 1 } ;
理解JavaScript中的对象理解JavaScript中的对象
var  p2  =   { x: 2, y: 2 } ;
理解JavaScript中的对象
var  p3  =  add(p1, p2);
理解JavaScript中的对象alert(p3.x 
+   " , "   +  p3.y);
2:将函数作为对象的方法。
理解JavaScript中的对象var  Boy =
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象    name:
"Young",
理解JavaScript中的对象理解JavaScript中的对象    Love:
function(Girl){
理解JavaScript中的对象            
return this.name+" 爱上了 "+Girl.name
理解JavaScript中的对象         }

理解JavaScript中的对象}

理解JavaScript中的对象理解JavaScript中的对象
var  Girl = {
理解JavaScript中的对象    name:
"Jing"
理解JavaScript中的对象}

理解JavaScript中的对象alert(Boy.Love(Girl));

    现在问题是两个类似的对象,一个有love方法,一个没有,因为我们并没有定义类似c#的类,而只是简单的创建两个对象,如果你期望在两个对象都有love方法可以象下面那样定义。

理解JavaScript中的对象理解JavaScript中的对象function  LoveRelation(person) {
理解JavaScript中的对象        alert(
this.name+" 爱上了 "+person.name);
理解JavaScript中的对象    }

理解JavaScript中的对象理解JavaScript中的对象
var  person1 = {
理解JavaScript中的对象    name:
"Young",
理解JavaScript中的对象    Love:LoveRelation
理解JavaScript中的对象}

理解JavaScript中的对象理解JavaScript中的对象
var  person2 = {
理解JavaScript中的对象    name:
"Jing",
理解JavaScript中的对象    Love:LoveRelation
理解JavaScript中的对象}

理解JavaScript中的对象person1.Love(person2);

     上面的代码看上去想创建一个person类,然后创建person类两个实例,以使这两个实例具有相同的特征,显然上面代码不够。我们可以通过两种途径来满足这种要求。
途径1:

理解JavaScript中的对象function  Person(n)
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象    
this.name=n;
理解JavaScript中的对象    
this.Love=function(person)
理解JavaScript中的对象理解JavaScript中的对象    
{
理解JavaScript中的对象        alert(
this.name+" 爱上了 "+person.name);
理解JavaScript中的对象    }

理解JavaScript中的对象}

理解JavaScript中的对象
var  person1 = new  Person( " Young " );
理解JavaScript中的对象
var  person2 = new  Person( " Jing " );
理解JavaScript中的对象person1.Love(person2);
途径2:利用JavaSctipt对象的prototype属性。
理解JavaScript中的对象function  Person(n)
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象    
this.name=n;
理解JavaScript中的对象}

理解JavaScript中的对象Person.prototype.Love
= function (person)
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象    alert(
this.name+" 爱上了 "+person.name);
理解JavaScript中的对象}

理解JavaScript中的对象
var  person1 = new  Person( " Young " );
理解JavaScript中的对象
var  person2 = new  Person( " Jing " );
理解JavaScript中的对象person1.Love(person2);
理解JavaScript中的对象person2.Love(person1);
      上面的例子中,我们可以将Person函数看成Person对象的构造器,而所有通过此构造器构造出来的对象共用一个prototype属性。
      在Douglas Crockford的<a href=" http://www.crockford.com/javascript/private.html">Private Members In JavaScript"</a>中,作者为我们详细的演示了如何创建对象的私有成员,其思想不再详细讲解,我们简单的重写一下那个demo
理解JavaScript中的对象function  Point(x, y)
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象理解JavaScript中的对象    
this.get_x = function() return x; }
理解JavaScript中的对象理解JavaScript中的对象    
this.set_x = function(value) { x = value; }
理解JavaScript中的对象理解JavaScript中的对象    
this.get_y = function() return y; }
理解JavaScript中的对象理解JavaScript中的对象    
this.set_y = function(value) { y = value; }
理解JavaScript中的对象}

理解JavaScript中的对象
理解JavaScript中的对象Point.prototype.print 
=   function ()
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象    
return this.get_x() + ',' + this.get_y();
理解JavaScript中的对象}

理解JavaScript中的对象
理解JavaScript中的对象
var  p  =   new  Point( 2 , 2 );
理解JavaScript中的对象p.set_x(
4 );
理解JavaScript中的对象alert(p.print());
      最后我们讲解一下javascript对象的命名空间,命名空间可以削除一些同名类型间的冲突,学习过c#的朋友对这点一定非常清除了,我们可以在javascript中通过以下代码开定义命名空间。
理解JavaScript中的对象理解JavaScript中的对象var  Arcadia  =   {}
理解JavaScript中的对象Arcadia.Person
= function (n)
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象    
this.name=n;
理解JavaScript中的对象}

理解JavaScript中的对象Arcadia.Person.prototype.Love
= function (person)
理解JavaScript中的对象理解JavaScript中的对象
{
理解JavaScript中的对象    alert(
this.name+" 爱上了 "+person.name);
理解JavaScript中的对象}

理解JavaScript中的对象
var  person1 = new  Arcadia.Person( " Young " );
理解JavaScript中的对象
var  person2 = new  Arcadia.Person( " Jing " );
理解JavaScript中的对象person1.Love(person2);