JS--我發現,原來你是這樣的JS:面向對象編程OOP[1]--(理解對象和對象屬性類型)


一、介紹

老鐵們,這次是JS的面向對象的編程OOP(雖然我沒有對象,心累啊,但是可以自己創建啊,哈哈)。
JS高程里第六章的內容,這章內容在我看來是JS中很難理解的一部分。所以分成三篇博客來逐個理清。
這是第一篇:理解對象,認識對象屬性的類型。

二、理解對象

書中原話--ECMA-262中把對像定義為:無序屬性的集合。其中屬性可以是基本值,對象或者是函數。

1.我們通俗點理解一下

對象是一個真實存在的東西,就像世上每一個人、每一個物體一樣,它有自己的屬性,行為。也就是說各種屬性集合在一起就是一個具體的對象。(你自己也是一個對象)

舉一些生活例子:
小明:有名字,年齡(基本值),說話(方法) 等屬性
電腦:有顏色,大小(基本值),cpu(對象)等屬性

2.我們js代碼理解一下:

1.用new Object()構造函數方法來創建對象

//obj是我創建的一個對象,它有name、age屬性,sayHi方法
var obj = new Object();
obj.name = "ry";
obj.age="3";
obj.sayHi = function(){
    console.log("Hi");
}

2.用對象字面量創建對象

//創建一個person對象
var person = {
    name : "ry",
    age : 3,
    sayBye: function(){
        console.log('bye bye');
    }
};

上面說這么多,就想說明白js中的對象是什么。總之:無序的屬性的集合 == 對象

三、理解對象屬性的類型

1.對象屬性有類型?奇怪嗎?

一開始我們對未知的事物都會充滿的疑惑和驚訝,但是知識這東西,我們更多的選擇去接受它,然后理解它,最后運用它。

  • 可能你會問對象屬性還有類型?一開始我也覺得驚訝。
  • 沒錯,對象屬性是有類型的,可能你不能理解,但只能接受。

2.對象屬性類型有哪些:數據屬性和訪問器屬性

對於對象屬性類型這塊,我們只是簡單的去了解有什么類型,類型區別。 這也有助於我們去了解對象。

1.數據屬性(最常用的)

既然有不同的類型,那肯定要有一個東西去區分他們,那這個東西就是特性

  • js中用特性這東西去區分屬性類型。對於數據屬性,它有以下4個特性去說明它是數據屬性
名字 作用
[[Configurable]] 表示能否通過delete來刪除屬性,能否修改屬性的特性,或能否把屬性設為訪問器屬性,默認true。
[[Enumerable]] 能不能通過for in枚舉該屬性,默認true。
[[Writable]] 能不能修改屬性值,默認true。
[[Value]] 這個位置保存屬性的值。比如下面的name屬性,它的[[Value]]就保存"ry"這個字符串
  • 數據屬性長什么樣子(也就那樣,以前那樣)
//一個對象
var person = {
    //這就是一個數據屬性
    name:"ry";
};
console.log(person.name); //ry
//透過代碼可以看出,以前我們定義對象屬性就是數據屬性,以前不知道它叫數據屬性這個名字,但現在知道了。
  • 測試一下特性吧。用Object.defineProperty(),修改特性用到這個函數Object.defineProperty():接受3個參數:屬性所在對象,屬性名字,描述符對象
//創建一個對象person
var person = {};
//添加一個數據屬性
person.name = "ry";
//使用Object.definProperty方法
Object.definProperty(person,"name",{
    //writable表示能不能修改,false表示不能
    writable:false,
})

console.log(person.name);  "ry"
//修改name的值
person.name = "yuan";
//name的值不變,修改不了
console.log(person.name);  "ry"

除此之外還可以修改其他特性,大家可以試試哦。

2.訪問器屬性

訪問器屬性的4個特性:

名字 作用
[[Configurable]] 表示能否通過delete來刪除屬性,能否修改屬性的特性,或能否把屬性設為訪問器屬性,默認true。
[[Enumerable]] 能不能通過for in枚舉該屬性,默認true。
[[Get]] 讀取時調用的函數,默認undefined
[[Set]] 寫入時調用的函數,默認undefined

訪問器屬性特性不包含數據值,它們包含一對getter和setter函數(但這兩個不是必須的)
訪問器屬性不能直接定義,只能通過Object.defineProperty()來定義。

▶ 書上的例子:

//一個對象
var book = {
    _year : 2004,
    edition : 1
};

//定義一個叫year的訪問器屬性
Object.defineProperty(book,"year",{
    //設置get特性,這是一個方法
    get: function(){
        retrun this._year;
    };
    //設置set特性
    set:function(newValue){
        if(newValue > 2004){
            this._year = newValue;
            this.edition += newValue - 2004;
        }
    }
});

//測試一下,給訪問器屬性賦值,即寫入year,它會調用set的方法
book.year = 2005;
//上面的2005大於2004,set方法中會改變edition的值,變成2
console.log(book.edtion); //2

▶ 特別提醒:Objecct.defineProperty() 的兼容性:IE9+,Firefox4+,chrome,Opera12+,Safari 5+

▶ 除此之外

  • 還有一次定義多個屬性的方法:Objecct.defineProperties() , 兼容性:IE9+,Firefox4+,chrome,Opera12+,Safari 5+。

  • 讀取屬性特性方法:Object.getOwnPropertyDescriptor(),接受兩參數:屬性所在對象和要讀取器描述符的屬性名稱。 返回一個對象。

//實踐比較容易理解
//一個對象
var book = {};
//用Objecct.defineProperties()方法設置多個屬性 
Object.defineProperties(book,{
    _year:{
        value:"ry"
    },
    edition:{
        value:1
    },
    year:{
        get:function(){
            return this._year ;
        }
    }
});

//函數返回一個對象
//descriptor對象有configurable,enumerable,writable,value屬性/(如果是訪問器屬性:configurable,enumerable,get,set)
//_year是數據屬性
var descriptor = Object.getOwnPropertyDescriptor(book,"_year");
console.log(descriptor.value);  //2004
console.log(descriptor.configurable);  //true
console.log(descriptor.enumerable);  //true
//數據屬性沒有get
console.log(descriptor2.get); //undefined

//year是訪問器屬性
var descriptor2 = Object.getOwnPropertyDescriptor(book,"year");
//訪問器屬性有get
console.log(descriptor2.get); //function

四、小結

這次介紹主要介紹:
1.什么是對象:無序屬性的集合。
2.還有屬性的類型:數據屬性和訪問器屬性。還有兩種屬性的各個特性,區別。不用深入,起碼知道有這些東西。
3.屬性的類型有個了解就好,主要用的還是數據屬性(平時用的)。
不忘初心,方得始終。覺得寫得很好就贊一下吧,也可以關注博主哦

同系列前幾篇:
第一篇:JavaScript--我發現,原來你是這樣的JS(一)(初識)
第二篇:JavaScript--我發現,原來你是這樣的JS(二)(基礎概念--軀殼篇)
第三篇:JavaScript--我發現,原來你是這樣的JS(三)(基礎概念--靈魂篇)
第四篇:JavaScript--我發現,原來你是這樣的JS(四)(看看變量,作用域,垃圾回收是啥)
第五篇:JavaScript--我發現,原來你是這樣的JS(引用類型不簡單[上篇],且聽我娓娓道來)
第六篇:JavaScript--我發現,原來你是這樣的JS(引用類型不簡單[下篇],基本包裝類型與個體內置對象)

本文出自博客園:http://www.cnblogs.com/Ry-yuan/
作者:Ry(淵源遠願)
歡迎轉載,轉載請標明出處,保留該字段。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM