使用Object.create()實現繼承
一、常見繼承方式
我們日常開發中常見的繼承方式主要有: 1、預設模式:
1 |
|
2、借用建構函式:
1 2 3 |
|
3、借用和設定原型:
1 2 3 4 |
this , arguments);
|
4、共享原型:
1 |
|
5、使用臨時建構函式:
1 2 3 |
|
6、extend屬性複製:
1 2 3 4 5 6 7 8 9 10 11 |
|
當然在一些javascript庫中(jQuery),還存在淺複製和深複製。 7、原型繼承模式:
1 |
|
二、Object.create實現繼承
本文將來學習第七種繼承方式Object.create()方法來實現繼承,關於此方法的詳細描述,請戳這裡。下面來通過幾個例項來學習該方法的使用:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
我們再來看一個例子,再新增一個繼承:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
|
通過上面可以看出Object.create()方法實現了鏈式繼承,及原型鏈的繼承。如果在控制檯打印出各個生成的物件,可以很清楚的看到。
1 2 3 4 |
|
isPrototypeOf() 方法測試一個物件是否存在於另一個物件的原型鏈上。 以上就是本文對Object.create方法的描述,文中不妥之處,還望批評指正。