/********** 把构造函数 Person 当做一个实例对象看待*********/ Person.speak = 'i am a person'; // 给实例对象添加属性 // 访问实例对象的属性 console.log(Person.speak); // i am a person /********** 把构造函数 Person 原原本本的当做构造函数看待*********/ var stud1 = new Person(); // 实例化 Person stud1.no = '201211513'; console.log(stud1.no); // 201211513
值得注意的是:在谷歌和火狐下,
如果一个事物确实可以视为实例对象,
则其隐藏属性 __proto__ 是可以访问的(注意前后都是两个下划线哦),
如果一个事物确实可以视为构造函数,
则其是拥有属性 prototype的,并且可以进行访问
例如:
console.log({}.__proto__); // Object{,等15项...} console.log({}.prototype); // undefined function a(){ } console.log(a.__proto__); // function() -->此处把函数a 视为实例对象 console.log(a.prototype); // Object{,等1项...} -->此处把函数a 视为函数(或构造函数) // 以上结果可以体现出函数(或称构造函数)的双重性
从对象和函数(或称构造函数)两个维度理解js中的函数
最新推荐文章于 2024-06-29 16:57:52 发布