構造函數
new Object()
new Object(value)
參數
value
可選的參數,聲明了要轉換成Number對象、Boolean對象或String對象的原始值(即數字、布爾值或字符串)。JavaScript 1.1之前的版本和ECMAScript Vl不支持該對象。
返回值
如果沒有給構造函數傳遞value參數,那麼它將返回一個 新創建的Object實例。如果指定了原始的value參數,構造函數將創建並返回原始值的包裝對象,即Number對象、Boolean對象或 String對象。當不使用new運算符,將Object()構造函數作為函數調用時,它的行為與使用new運算符時一樣。
屬性
constructor
對一個JavaScript函數的引用,該函數是對象的構造函數
方法
1.hasOwnProperty( )
檢查對象是否有局部定義的(非繼承的)、具有特定名字的屬性。
代碼如下:
<script type="text/javascript">
var o = new Object();
o.name="Tom";
alert(o.hasOwnProperty("name")); //true
alert(o.hasOwnProperty("age")); //false
</script>
2.isPrototypeOf()
語法
object.isPrototypeOf(o)
參數
o
任意對象。
返回值
如果object是O的原型,則返回true。如果o不是對象,或者object不是o的原 型,則返回false。
描述
JavaScript對象繼承了原型對象的屬性。一個對象的原型是通過用於創建並初始化該對象的構造函數的prototype屬性引用的。isPrototypeOf()方法提供了判斷一個對象是否是另一個對象原型的方法。該方法可以用於確定對象的 類。
示例
代碼如下:
var o = new Object( ); // 創建一個對象
Object.prototype.isPrototypeOf(o) // true: o 是一個對象
Function.prototype.isPrototypeOf(o.toString); // true: toString 是一個函數
Array.prototype.isPrototypeOf([1,2,3]); // true: [1,2,3] 是一個數組
//下面是執行同樣測試的另一種方法
(o.constructor == Object); // true: o was created with Object( ) constructor
(o.toString.constructor == Function); // true: o.toString is a function
/原型則對象本身於原型對象。下面的調用返回true
//說明函數繼 Function.prototype和Object.prototyp屬性.
Object.prototype.isPrototypeOf(Function.prototype);
3.ProertyIsEnumerable()
語法
object.propertyIsEnumerable(propname)
參數
propname
一個字符串,包含object原型的名字。
返回值
如果object具有名為propname的非繼承屬性,而且該屬性是可枚舉的(即用for/in循環可以枚舉出它),則返回true。
描述
用for/in語句可以遍歷一個對象“可枚舉”的屬性。但並非—個對象的所有屬性都是可枚舉的,通過JavaScript代碼添加到對象的屬性是可枚舉的,而內部對象的預定義屬性(如方法)通常是不可枚舉的。propertylsEnumerable()方法提供了區分可枚舉屬性和不可枚舉屬性的方法。但要注意,ECMAScript標准規定,propertyIsEnumerable()方法不檢測原型鏈,這意味著它只適用於對象的局部屬性,不能檢測繼承屬性的可枚舉性。
示例
代碼如下:
var o = new Object( ); // 創建一個對象
o.x = 3.14; // 定義—個屬性
o.propertyIsEnumerable("x"); // true屬性x是局部的、可枚舉的
o.propertyIsEnumerable("y"); //false:o沒有屬性y
o.propertyIsEnumerable("toString"); //false:toStrlng屬性是繼承的
Object.prototype.propertyIsEnumerable("toString"); // false: 枚舉的
Bug
當標准限制propertylsEnumerable()方法只能檢測非繼承屬性時,明顯是錯的。 Internet Explorer 5.5按標准實現了該方法。Nestacpe 6.0實現的propertyIsEnumerable()方法考慮了原型鏈。雖然這種方法可取,但它與標准沖突,所以Netscape 6.1修改了它,以便與IE 5.5匹配。由於標准中有這個錯誤,因此該方法不是那麼有用。
代碼如下:
<script>
var obj = new Object();
obj.title = 'aaa';
obj.funb = function(a, b)
{
alert(a+b);
}
alert(obj.title);
obj.funb(1,2);
</script>
這裡一種方法
******************************
代碼如下:
<script language="javascript">
function object(value,a,b){
this.title = value;
this.funb = function(){
this.a = a;
this.b = b;
alert(a+b);
}
}
var obj = new object("aaa",1,2);
alert(obj.title);
obj.funb();
//這裡為對象添加新的方法
object.prototype.name = "123456";
alert(obj.name);
</script>
這是另一種方法