您的位置:首页 > Web前端 > JavaScript

从对象和函数(或称构造函数)两个维度理解js中的函数

2017-07-23 11:49 357 查看
/********** 把构造函数 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 视为函数(或构造函数)

// 以上结果可以体现出函数(或称构造函数)的双重性






                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息