随笔 - 2146  文章 - 97 评论 - 11767 trackbacks - 253


和 Delphi/C# 类似, JavaScript 中所有对象的祖先是 Object, 虽然并不是全部面向对象的, 好像也是基于对象的.
譬如一个字符串类型(string)变量, 可以使用字符串对象(String)的属性和方法, 那是在调用的一瞬间转换成了对象.

建立原始空对象的两种方法
var obj1, obj2;
obj1 = new Object();
obj2 = {};

alert(obj1); // [object Object] - 属于 Object 类的 object
alert(obj2); // [object Object]

//上面两种方法建立的对象都可以使用以下六个方法(不如说是抽象方法):
hasOwnProperty
isPrototypeOf
propertyIsEnumerable
toLocaleString
toString
valueOf

//Object 像不像个接口? 像也不像, 因为以上方法它并不强迫子类实现.


//现在应该让人立马想起空数组的两种建立方法:
var arr1, arr2;
arr1 = new Array();
arr2 = [];

//Array 作为 Object 的子类, 继承或重新实现了上面方法, 并且增加了 sort 等更多数组专用的方法.

//一个是 {}、 一个是 [], 很有意思; 更有意思的是它们可以互相包含.


定义自己的对象
//已存在 Array、Number、Date、RegExp 等实用的类(或叫对象模板), 如果构建自己的类呢?
//很简单, 但不好理解:

function Rectangle(w, h) {
  this.w = w;
  this.h = h;
}

/* 实例化一个 */
var myObj = new Rectangle(11, 22);
alert(myObj.w); //11
alert(myObj.h); //22
alert(myObj);   // [object Object]

//可以看出 myObj 就是一个对象了; 在 js 中函数也是对象, 并且有一个 Function 类存在.

//可以在 Rectangle(函数? 类?) 的基础上继续添加更多方法或属性, 这是后话.


JavaScript Object Notation - json
//js 用 {} 标识对象的方法(JavaScript Object Notation)被简称为 json;
//说到 json, 佩服其的设计者, 本来是语言中描述对象的一种规则, 现在竟被推崇为超越 XML 的数据格式.

var obj = {name:'张三', age:88, marriage:true};

//{} 中的数据用 , 号隔开, 每个数据又是 Name : Value 的形式;
// : 前面的标识符是比不可少的, 它将是对象的属性或方法等, 它也可以在引号中, 也支持中文.

/* 访问 Value 方法一 */
alert(obj.name);     //张三
alert(obj.age);      //88
alert(obj.marriage); //true

/* 访问 Value 方法二 */
alert(obj['name']);     //张三
alert(obj['age']);      //88
alert(obj['marriage']); //true

/* 遍历 Value */
for (var k in obj) {
  alert(obj[k]);      //张三 / 88 / true
}

/* 遍历 Name */
for (var k in obj) {
  alert(k);           //Name / age / marriage
}

//对象还可以继续包含对象, 再连同数组互相嵌套, 因而 json 能表达非常复杂的数据结构.


给自定义的类添加方法
var obj = {
  name : '张三', 
  age : 88, 
  marriage: false,
  info: function() {return this.name + '今年 ' + this.age + ' 岁, ' + (this.marriage ? '已经结婚了.' : '至今未婚.')}
};

alert(obj.info());    //张三今年 88 岁, 至今未婚.
alert(obj['info']()); //张三今年 88 岁, 至今未婚.

obj.name = '李四';
obj.age = 18;
obj.marriage = true;

alert(obj.info()); //李四今年 18 岁, 已经结婚了.

//还有其他方法, 后续.


posted on 2009-03-02 20:48  万一  阅读(...)  评论(...编辑  收藏