淺談javascript面向?qū)ο蟪绦蛟O(shè)計
ECMA-262把對象定義為:“無序?qū)傩缘?集合,其屬性可以包含基本值、對象或者函數(shù)”
理解對象,最簡單的方式就是通過創(chuàng)建一個Object的實例,然后為它添加屬性和方法
var person = new Object();
person.name = "Xulei";
person.age = "23";
person.job = "前端工程師";
person.sayName = function () {
alert(this.name);
}
還可以這樣寫
var person = {
name: "xulei",
age: 23,
job: "前端工程",
sayName: function () {
alert(this.name)
}
}
一、屬性類型:數(shù)據(jù)屬性和訪問其屬性
1、數(shù)據(jù)屬性,有4個描述其行為的特性
[Configurable]:表示能否通過delete刪除屬性從而重新定義屬性,能否修改屬性的特性,或者能否把屬性修改為訪問器屬性,默認(rèn)值為true
[Enumerable]:表示能否通過for-in返回屬性,默認(rèn)值為true
[Writable]:表示能否修改屬性,默認(rèn)值為true
[Value]:包含這個屬性的數(shù)據(jù)值。默認(rèn)值為undefined
var person = {
name: "xulei"
}
這里創(chuàng)建了一個person對象,value值就是“xulei”
要修改屬性的默認(rèn)特性,必須使用ECMAScript5的Object.defineProperty(屬性所在的對象,屬性的名字,描述符對象)
描述符對象必須是configurable、enumerable、writable、value
var peron = {}
Object.defineProperty(peron, "name", {
writable: false,//屬性不能被修改
value: "徐磊-xulei"
});
alert(peron.name);//徐磊-xulei
peron.name = "徐磊";
alert(peron.name);//徐磊-xulei
以上操作在非嚴(yán)格模式下賦值操作會被忽略,如果在嚴(yán)格模式下會拋出異常
一旦把屬性定義為不可配置的就不能把它變回可配置的了。
在多數(shù)情況下都沒有必要利用Object.defineProperty()方法提供的這些高級功能。但是對理解javascript非常有用。
建議讀者不要在ie8上使用此方法。
2、訪問其屬性,有4個特性
[Configurable]:表示能否通過delete刪除屬性從而重新定義屬性,能否修改屬性的特性,或者能否把屬性修改為訪問器屬性,默認(rèn)值為true
[Enumerable]:表示能否通過for-in返回屬性,默認(rèn)值為true
[Get]:在讀取時調(diào)用的函數(shù)
[Set]:在寫入屬性時調(diào)用的函數(shù)
相關(guān)文章
JS實現(xiàn)PC手機端和嵌入式滑動拼圖驗證碼三種效果
這篇文章主要介紹了JS實現(xiàn)PC手機端和嵌入式滑動拼圖驗證碼三種效果,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02JS設(shè)計模式之責(zé)任鏈模式應(yīng)用詳解
JS責(zé)任鏈模式是一種行為型設(shè)計模式,它允許多個對象按照順序處理請求,直到其中一個對象能夠處理請求為止,這樣的對象鏈被稱為責(zé)任鏈,本文將給大家詳細(xì)講講責(zé)任鏈模式在JS中的應(yīng)用,需要的朋友可以參考下2023-08-08深入理解JavaScript中的call、apply、bind方法的區(qū)別
下面小編就為大家?guī)硪黄钊肜斫釰avaScript中的call、apply、bind方法的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05