首页 > 代码库 > JS学习笔记02-初识原型
JS学习笔记02-初识原型
<!DOCTYPE HTML> <html lang="en"> <head> <meta charset="UTF-8"> <title>test</title> <style type="text/css"> </style> </head> <body> <script type="text/javascript"> //◆ 所有对象都继承自Object.prototype,它在原型链中是最后一个。 Object.prototype.age = 1; var obj1 = {}; console.log(obj1.age); if (‘age‘ in obj1){ console.log(obj1.hasOwnProperty(‘age‘));//验证是否来自本地对象 }
/* ◆ 每个function都具有prototype属性,对象都有隐式的__proto__。 ◆ 通过function实例化的对象,对象本身的__proto__指向function的prototype。 ◆ 对象本身的constructor指向function。 */ function f(){ this.age=2; } debugger; var obj2 = new f(); console.log(obj2.__proto__===f.prototype);//true 对象本身的__proto__指向function的prototype console.log(obj2.__proto__.__proto__===f.prototype.__proto__? f.prototype.__proto__===Object.prototype:‘false‘);//true console.log(obj2.constructor===f);//true //对象本身的constructor指向function console.log(f.prototype.isPrototypeOf(obj2));//true 检测obj2是否是f生成的对象
//分解上面new创建的过程 var obj3 = {}; //创建一个空对象 obj3.__proto__===Object.prototype obj3.__proto__=f.prototype; //使对象__proto__指向__prototype f.call(obj3); //将f的this替换成obj3,然后再调用f函数. console.log(obj3.__proto__===f.prototype);// true console.log(obj3.constructor===f);// true </script> </body>
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。