博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS创建对象模式及其对象原型链探究(一):Object模式
阅读量:6510 次
发布时间:2019-06-24

本文共 3848 字,大约阅读时间需要 12 分钟。

Object模式

创建一个Object实例,再为其添加属性和方法。

这是创建自定义对象最简单的方式。

1.创建对象

// 创建person对象var person = new Object();person.name = "Mike";person.age = 20;person.job = "student";person.showName = function(){        console.log("this.name = " + this.name);};person.consThis = function(){    console.log("this = ");        console.log(this);    // this指向person对象        console.log(this === person);};person.showName();person.consThis();

输出如图:

图片描述

2.观察下person.showName属性引用的函数

// person.showName引用的是一个匿名函数,其name属性为""console.log("person.showName.name=");console.log(person.showName.name);console.log(person.showName.name === "")console.log("-----分割线-----");// showName引用的匿名函数的prototype属性指向其原型对象console.log("person.showName.prototype=");console.log(person.showName.prototype);console.log(person.showName.prototype === Function.prototype);        //不是Function构造函数的原型对象console.log("-----分割线-----");//其原型对象的constructor属性指向showName引用的匿名函数console.log("person.showName.prototype.constructor=");        console.log(person.showName.prototype.constructor);        console.log("-----分割线-----");// 此匿名函数的原型对象的__proto__属性指向Object构造函数的原型对象console.log("person.showName.prototype.__proto__=");console.log(person.showName.prototype.__proto__);console.log(person.showName.prototype.__proto__ === Object.prototype);console.log("-----分割线-----");// showName引用的匿名函数的__proto__属性指向Function.prototypeconsole.log("person.showName.__proto__=");        //showName引用的是一个匿名函数,匿名函数本质上是由构造函数Function生成的console.log(person.showName.__proto__);        //showName引用的是一个匿名函数,匿名函数本质上是由构造函数Function生成的// 验证console.log(person.showName.__proto__ === Function.prototype);    //trueconsole.log("-----分割线-----");

showName属性引用的匿名函数信息:

图片描述

输出如图:

图片描述

3.观察person对象涉及到的原型链

Object构造函数的原型链

// prototype属性指向Object构造函数的原型对象console.log("Object.prototype=");console.log(Object.prototype);// Object构造函数的原型对象的constructor属性指向其本身console.log("Object.prototype.constructor=");console.log(Object.prototype.constructor);console.log("-----分割线-----");//所有构造函数(内置及自定义)的__proto__属性都指向Function构造函数的原型对象// __proto__指向Function构造函数的原型对象,即Function.prototypeconsole.log("Object.__proto__=");console.log(Object.__proto__);    console.log(Object.__proto__ === Function.prototype);    console.log("-----分割线-----");

图片描述

person对象的原型链

// person是对象,非函数,所以没有prototype属性console.log("person.prototype=");console.log(person.prototype);console.log("-----分割线-----");// 所有对象的__proto__都指向其构造器的prototype// person的__proto__属性指向构造函数的原型对象,即Object构造函数的原型对象console.log("person.__proto__=");console.log(person.__proto__);// 验证console.log(person.__proto__ === Object.prototype)    //trueconsole.log("-----分割线-----");

图片描述

构造函数的原型对象的类型

// Function.prototype的类型为functionconsole.log("typeof Function.prototype:");console.log(typeof Function.prototype);    // 除了Function构造函数的原型对象为function,其他构造函数的原型对象类型为object// Object.prototype的类型为objectconsole.log("typeof Object.prototype:");console.log(typeof Object.prototype);// Array.prototype的类型为objectconsole.log("typeof Array.prototype:");console.log(typeof Array.prototype);console.log("-----分割线-----");

图片描述

Function构造函数的原型对象和Object构造函数的原型对象的关系

// Function.prototype.__proto指向Objcet.prototypeconsole.log("Function.prototype.__proto__=");console.log(Function.prototype.__proto__);// 验证console.log(Function.prototype.__proto__ === Object.prototype);    //true// 这说明所有的构造器也都是一个普通JS对象,可以给构造器添加/删除属性等。同时它也继承了Object.prototype上的所有方法:toString、valueOf、hasOwnProperty等。console.log("-----分割线-----");// Object.prototype.__proto指向nullconsole.log("Object.prototype.__proto__=");console.log(Object.prototype.__proto__);// 原型链到顶了,为null。

原型分析

  • 所有构造器/函数的_ proto _都指向Function.prototype

  • 所有对象的_ proto _都指向其构造器的prototype

  • 除了Function构造函数的原型对象为function,其他构造函数的原型对象类型为object

  • 所有的构造器也都是一个普通JS对象,可以给构造器添加/删除属性等。同时它也继承了Object.prototype上的所有方法:toString、valueOf、hasOwnProperty等。

  • person对象是由Object构造函数创建而成的,所以它的_ proto _指向Object.prototype

原型链图

person对象的原型链图:

图片描述

person对象showName属性引用的匿名函数的原型链图:

图片描述

转载地址:http://lydfo.baihongyu.com/

你可能感兴趣的文章
阿里云中间件推出全新开发者服务
查看>>
56.随机产生的id重复问题
查看>>
一个快速检测系统CPU负载的小程序
查看>>
java.lang.IllegalArgumentException: No bean specified
查看>>
Wireshark and Tcpdump tips
查看>>
第一课 计算机及操作系统基础知识
查看>>
windows2003单域迁移到2008R2服务器
查看>>
cacti相关资料网站
查看>>
我的友情链接
查看>>
网站的开发流程介绍(转)
查看>>
java面向对象中的方法重载与方法重写的区别
查看>>
浅析:Android--Fragment的懒加载
查看>>
Linux操作系统目录和Linux常用的文件和目录管理命令
查看>>
shell运算(加、减、乘、除)
查看>>
DIY:自己动手做一个迷你 Linux 系统(二)
查看>>
猫猫学IOS(三十)UI之Quartz2D画图片画文字
查看>>
【分享】一个通用强大的主数据管理系统(架构设计讲解及源码下载)
查看>>
windows 指定的网络名不可用__被我解决了!
查看>>
asp.net 动态编译与禁止
查看>>
好程序员java教程分享+号与append的效率问题
查看>>