-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path019_oop3.htm
More file actions
95 lines (72 loc) · 2.88 KB
/
019_oop3.htm
File metadata and controls
95 lines (72 loc) · 2.88 KB
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script type=text/javascript charset=utf-8>
// isPrototypeOf(new instance); 判断原型的方法
// ECMA5: Object.getPrototypeOf():根据实例对象获得原型对象
function Person(){
}
Person.prototype.name = 'z3';
Person.prototype.age = 20 ;
Person.prototype.sayName = function(){alert('我是原型对象的方法!')};
// var p1 = new Person();
// alert(p1.name); // z3
// var prototypeObj = Object.getPrototypeOf(p1);
// alert(prototypeObj);
//alert(prototypeObj == Person.prototype); // 构造函数的prototype == 对象的prototype
/* 每次代码读取一个对象的属性的时候: 首先会进行一次搜索:搜索实例对象里name的属性,看看有没有
* 如果没有,再去p2的实例所对应的原型对象里去搜索name属性 如果有就返回 没有返回undefined
*/
// var p2 = new Person();
// p2.name = 'w5'; // 实例对象的name
// alert(p2.name);
// delete p2.name ;
//alert(p2.name); // 就想获得原型对象的name属性
// 判断一个对象属性 是属于原型属性 还是属于实例属性
/*
var p3 = new Person();
p3.name = 'z6';
p3.sex = '1';
alert(p3.sex);
alert('sex' in p3);
alert(p3.hasOwnProperty('sex'));
*/
//in 操作符 : for-in
// in 操作符 判断属性是否存在于 实例对象和原型对象中(在实例或者原型任意对象中)
/*
var p1 = new Person();
alert('name' in p1); // true
var p2 = new Person();
p2.name = 'w3';
alert('name' in p2); // true
*/
// 就是判断一个属性 是否存在原型中
// 在原型对象中 是否存在这个属性 第一个参数:当前对象 ,第二个参数:要判断的属性
function hasPrototypeProperty(object , name){
return !object.hasOwnProperty(name) && name in object ;
}
/*
var p3 = new Person();
p3.name = 'xiao A';
alert(hasPrototypeProperty(p3,'name'));
*/
// ECMA5新特性 Object.keys();
// 拿到当前对象里的所有keys 返回一个数组
var p1 = new Person();
p1.name = 'z3';
p1.age = 20 ;
var attributes = Object.keys(p1);
alert(attributes);
var attributes2 = Object.keys(Person.prototype);
alert(attributes2);
//ECMA5 constructor属性: 该属性是不能被枚举的[eable = false]
//Object.getOwnPropertyNames 枚举对象所有的属性 :不管该内部属性能否被枚举
var attributes3 = Object.getOwnPropertyNames(Person.prototype);
alert(attributes3);
</script>
</head>
<body>
</body>
</html>