JavaScript之對象

什么是面向對象:

ECMAScript 有兩種開發模式:1.函數式(過程化),2.面向對象(OOP)。面向對象的語言有一個標志,那就是類的概念,而通過類可以創建任意多個具有相同屬性和方法的對象。 但是,ECMAScript 沒有類的概念,因此它的對象也與基于類的語言中的對象有所不同。


面向對象編程(OOP)的特點:

??? 封裝:不考慮內部實現,只考慮功能使用

??? 繼承:從已有對象上,繼承出新的對象

??? 多態:同一個函數調用會有不同的執行效果

對象的組成

??? 方法——函數:過程、動態的

??? 屬性——變量:狀態、靜態的


為對象添加方法和屬性:

?? 創建對象:var obj=new Object();

?? 添加屬性:obj.name=‘abc’;

?? 添加方法:obj.show=function(){alert(this.name)}

注 :不能在系統對象中隨意附加方法、屬性,否則會覆蓋已有方法、屬性


構造函數:

構造函數與其他函數的唯一區別在于調用它們的方式,任何函數,只要通過new操作符來調用,就可作為構造函數;而任何函數,若不通過new操作符調用,就是普通函數。


什么是原型:

??? 原型可以讓所有對象實例共享它所包含的屬性和方法

為Array添加sum方法:

???? 給對象添加方法,類似于行間樣式

???? 給原型添加方法,類似于class

原型的小缺陷:

??? 無法限制覆蓋


用混合方式構造對象:

??? 混合的的構造函數/原型方式

??? Mixed Constructor Function/Prototype Method

原則:

??? 構造函數:加屬性

??? 原型:加方法

對象命名規范:

??? 類名首字母大寫



構造函數偽裝???? call()方法:

定義:應用某一對象的一個方法,用另一個對象替換當前對象。

語法: Function.call(obj,arg1,arg2,…)方法能接收多個參數

??? obj:這個對象將代替Function類里this對象

??? arg:這個是參數,它將作為參數傳給Function

如果沒有提供 arg和 obj任何一個參數,那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數。


構造函數偽裝? apply()

定義:應用某一對象的一個方法,用另一個對象替換當前對象。

語法: Function.apply(obj,args)方法能接收兩個參數

??? obj:這個對象將代替Function類里this對象

??? args:這個是數組,它將作為參數傳給Function(args-->arguments)

如果沒有提供 args 和 obj任何一個參數,那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數。


ECMAScript只支持實現繼承,且其實現繼承主要依靠原型鏈來實現

原型鏈:

原型鏈的基本思想是利用原型讓一個引用類型繼承另一個引用類型的屬性和方法


instanceof操作符:

是一個運算符,運算中需要兩個操作數,運算的結果是true或false,表示此值是不是某一個類的示例,能得到一個值的具體類型。


什么是閉包?

函數 嵌套函數,內部函數可以引用外部函數的參數和變量,參數和變量不會被垃圾回收機制所收回


閉包有什么好處?應用在那里?

好處:

1.希望一個變量長期駐扎在內存當中

2.避免全局變量的污染

3.私有成員的存在

應用:

1.模塊化代碼

2.在循環中直接找到對應元素的索引


閉包需要注意得地方??????

?IE下會引發內存泄漏


本地對象(非靜態對象):

??? 常用對象

????????? Object、Function、Array、String、Boolean、Number、Date、RegExp、Error


內置對象(靜態對象):

?????????? Global、Math


宿主對象(由瀏覽器提供的對象):

??? DOM、BOM

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,763評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,238評論 3 428
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,823評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,604評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,339評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,713評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,712評論 3 445
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,893評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,448評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,201評論 3 357
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,397評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,944評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,631評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,033評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,321評論 1 293
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,128評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,347評論 2 377

推薦閱讀更多精彩內容