創(chuàng)建對象
•對象直接量
var o = { foo : "bar" } 	•構(gòu)造函數(shù)
var o = new Object();
•原型繼承
var p = Object.create(o);
類繼承
Javascript對象擁有自有屬性和繼承屬性。
•在查詢對象o的屬性x時,先查找o中的屬性x,如果沒找到,則查找o的原型對象中的x屬性,直到查找到x或者一個原型是null的對象為止
•在給對象o的x屬性賦值時,如果o中已經(jīng)有一個自有屬性x,則改變x的值,若o中不存在屬性x,則為o創(chuàng)建一個x屬性并賦值
•也就是說,只有在查詢時原型鏈才會起作用。
var O = { x : 1 };function P() { this.y = 2; }P.prototype = O;var t = new P(); console.log(t); console.log('x' in t);//true console.log(t.hasOwnProperty('x'));//false 	可以使用in 或者 hasOwnProperty 來判斷對象中是否存在屬性。
對象屬性
		 •遍歷對象屬性
		 
		可以使用 for..in 來遍歷對象的屬性
使用for..in時會遍歷到原型鏈上的屬性。遍歷順序是以廣度優(yōu)先遍歷
所以使用hasOwnProperty便可以判斷是否是對象自有的屬性。
		 •對象屬性的特性
		 
		使用Object.getOwnPropertyDescriptor()獲取對象特定屬性的描述符
可寫性(writable) 表示對象屬性是否可寫
例如
var o = {  foo : 'bar'}Object.defineProperty(o, "foo", { writable : false });o.foo = 'world';console.log(o.foo);//仍然輸出bar	可枚舉性(enumerable) 表示對象屬性是否可枚舉
		例如
		 Array中的length等屬性的 enumerable是false,所以,
for (p in Array) {  console.log(p);}	什么也不輸出
可配置性(configurable) 表示可否修改屬性的可配置性和可枚舉性
		可以用Object.defineProperties來定義這些配置屬性。
		Object.defineProperty(o, "foo", { writable : false });
		 Get 表示獲取對象屬性的方法
		Set 表示設(shè)置對象屬性的方法
示例
var book = {  _year: 2004,  edition: 1};Object.defineProperty(book, "year", {  get: function () {    console.log('get year');    return this._year;  },  set: function (newValue) {    console.log('set year');    if (newValue > 2004) {      this._year = newValue;      this.edition += newValue - 2004;    }  }});book.year = 2005;//控制臺輸出‘set year'console.log(book.year);//控制臺輸出‘get year'和year的值	對象方法
toString 將對象轉(zhuǎn)換成字符串,默認(rèn)的轉(zhuǎn)換會是[object Object]之類的東西,所以需要轉(zhuǎn)成json格式的話可以用JSON.stringify
		valueOf 需要將對象轉(zhuǎn)換成其他類型的時候要用到。同樣的,默認(rèn)轉(zhuǎn)換沒什么值得說的。
		 
		可執(zhí)行對象
通過如下方法可以創(chuàng)建一個可執(zhí)行對象
function bar(o) {  var f = function() { return "Hello World!"; }  o.__proto__ = f.__proto__;  f.__proto__ = o;  return f;}var o = { x: 5 };var foo = bar(o);console.log(foo());console.log(foo.x);console.log(typeof foo);//function	既可以當(dāng)作對象來使用(有原型鏈),也可以當(dāng)作函數(shù)來直接調(diào)用
新聞熱點
疑難解答
圖片精選