什么是constructor属性?它来自哪里?又将会指向何处?

什么是constructor属性?
constructor是构造函数属性。
它来自哪里?
其实constructor属性是来自 prototy原型属性 所指向的那个对象的属性,如果不明白这里的“那个对象”具体指的是哪个对象,可以看看我上一章讲的javascript面向对象——prototype属性(原型属性),里面有着详细的讲解。
又将指向何处?
从constructor属性的字面意思我们就不难看出,它指向的永远都是构造函数。
例如:
我们看看下面代码:

function myfile(name,age){
this.webname = name;
this.age = age;
}
myfile.prototype.getname = function () {
return this.age;
}
var myfile1 = new myfile("zhang",3);
console.info(myfile1.constructor);
console.info(myfile.constructor);
console.info(myfile.prototype.constructor);

这里我打印了在3种不同情况下所输出的constructor构造函数属性的内容,我将谷歌浏览器控制台打印出的结果截图如下:

是的正如我们看见的为什么console.info(myfile1.constructor);打印出的结果与console.info(myfile.prototype.constructor);打印出的结果会是一样的,而console.info(myfile.constructor);打印出的结果却是ƒ
 Function() { [native code] },其实这个很好理解,如果你看了我的上一章讲解的javascript面向对象——prototype属性(原型属性)那么我相信这个地方就会很容易理解,其实我们首先要清楚constructor构造函数属性,它是谁的属性?它是原型属性prototype所指向的那个对象的属性。那么在这个对象中这个属性它又指向谁呢!?它指向的是构造函数也就是上面代码中的function
 myfile(name,age){this.webname = name; this.age = age;}这一部分,其值就是这个构造函数中的对象。
那么肯定会有人疑问,既然 
constructor构造函数属性 指向的是是构造函数,那么打印出的结果是构造函数这个可以理解但是为什么console.info(myfile.prototype.constructor);打印的也是构造函数呢!?它指向的可不是构造函数,是的我们知道实例化对象指向的一直都是prototype原型属性所指向的对象。如果想解决这个问题,那么我们首先应该弄明白两个问题。
1、实例化对象到底指向的是谁?
2、实例化对象到底继承的是谁?
首先我们还是用一个实例来引入,用图片看结果然后在总结:
代码部分:

function myfile(name,age){
this.webname = name;
this.age = age;
}
myfile.prototype.getname = function () {
return this.age;
}
var myfile1 = new myfile("zhang",3);
console.info(myfile1.constructor);

总结:代码执行的结果在控制台上显示的内容如上图,打印出的是构造函数的代码也就是代码部分

function myfile(name,age){
this.webname = name;
this.age = age;
}

的的内容,有人肯定会想,哎!!!这不很明显嘛,实例化对象指向的就是构造函数啊!继承的也是构造函数。
那么我们来运行另外一句代码:console.info(myfile1.getname());打印出的结果却是3。

 
什么情况在上面的构造函数中并没有getname()这个函数对象啊!为什么会打印出结果3呢!我们可以仔细看看getname()这个对象是在什么地方出现的,是的它是通过原型属性直接定义的,通过上面的两次打印我们可以很明显的发现实例化对象不仅能够打印出构造函数还能够打印出通过原型链来创建的属性以及属性值,换句话说,也就是实力化的对象继承的对象并不全是构造函数,而是指向了一个我们看不见的对象,这个对象里面包含的有构造函数,还有通过原型链来创建的属性,那么这个对象是什么呢!其实我们在创建构造函数的时候,每个构造函数都会有一个prototype原型属性,这个原型属性会指向一个我们看不见的对象,我们可以通过原型属性来创建固定不变的属性并赋值,如:myfile.prototype.getname
 = function () {return this.age;}这个时候原型属性所指向的对象不仅包含了构造函数还包含了通过原型属性所创建出来的一些属性。
上面两个问题的答案就出来了:
1、实例化对象到底指向的是谁?
答:实例化对象指向的永远是prototype原型属性所指向的那个对象,是通过实例化对象的内部属性[[prototype]]来实现的。
2、实例化对象到底继承的是谁?
答:其实实例化对象继承的还是prototype原型所指向的那个虚拟的对象。
总结constructor(构造函数属性):
这个时候我们在来看看 console.info(myfile1.constructor); console.info(myfile.constructor);
console.info(myfile.prototype.constructor);三个为什么第一个跟第三个的值是一样的但是第二个会出现
ƒ Function() { [native code] } 。
console.info(myfile.prototype.constructor);其实就是在告诉计算机我们要的结果是prototype原型属性所指向的那个对象中的构造函数,而因为console.info(myfile1.constructor);本来就是直接继承的就是prototype原型属性所指的对象所以这两个命令打印出的结果自然也都是来之那个虚拟的对象中,这就是为什么这两个代码所执行出来的结果是一样的原因。至于console.info(myfile.constructor);执行出来的结果是ƒ
 Function() { [native code] } 就更好理解了,native code
的意思就是 本机代码 其实意思就是告诉我们,我们所执行的console.info(myfile.constructor);代码就是构造函数它自己本身,不能所执行这条代码会报错,只是控制台会更智能一些的告诉我们,我们需要打印的就是它自己而已。
现在你知道了constructor构造函数属性是属于谁的属性吗?
答:
1、它是prototype原型属性所指向的那个虚拟对象的属性。
2、它是实例化对象的属性。
从上面的例子中我们也能推断出上面的两条答案是成立的。
--------------------- 
作者:待归魔帝 
来源:CSDN 
原文:https://blog.csdn.net/zhj145236/article/details/77477057 
版权声明:本文为博主原创文章,转载请附上博文链接!

面向对象object与constructor的更多相关文章

  1. 理解JAVA - 面向对象(object) - 属性,方法

    理解JAVA - 面向对象(object) - 属性,方法 多态的体现:    向上造型,父类接收子类对象:向上造型:    从父类角度看不到子类独有的方法:面向对象,人类认知世界的方式:生活中每天都 ...

  2. Java - 面向对象(object oriented)计划 详细解释

    面向对象(object oriented)计划 详细解释 本文地址: http://blog.csdn.net/caroline_wendy/article/details/24058107 程序包括 ...

  3. Java面向对象 Object类 内部类

     Java面向对象 Object类    内部类 知识概要:                 一:Object类                 二:内部类 匿名内部类的写法 1.Object O ...

  4. ABAP 面向对象(Object Orientation) OO

    [转自 http://blog.sina.com.cn/s/blog_7c7b16000101bhof.html]在程序中, 对象的识别和寻址是通过对象引用来实现的, 对象引用变量可以访问对象的属性和 ...

  5. Object.prototype.constructor

    Returns a reference to the Object function that created the instance's prototype. 注意这个属性的值是函数本省的引用,而 ...

  6. 面向对象-Object类

    一.Object类中的equals()方法 equals(Object obj) :指示其它某个对象是否与此对象"相等". 返回值类型是boolean Oblect类中的equal ...

  7. php面向对象Object

    1.创建类 class 类名{ private 私有变量 只能本类的内部使用 protected 受保护的变量 本类和子类的内部 public 公开的变量 都可以使用 一般属性都设为私有 一般函数都是 ...

  8. The comparison between object and constructor

    1.相似的地方 1.举个栗子:public struct Student{    string name;    int age;}public class bike{    int weight;  ...

  9. Js中Prototype、__proto__、Constructor、Object、Function关系介绍

    一. Prototype.__proto__与Object.Function关系介绍 Function.Object:都是Js自带的函数对象.prototype,每一个函数对象都有一个显式的proto ...

随机推荐

  1. 微信小程序onLaunch修改globalData的值

    //app.js App({ onLaunch: function (options) { //设置场景值到缓存中: //wx.setStorageSync("scene", op ...

  2. Python标准库映射类型与可散列数据类型的关系

    这里有两个概念似懂非懂,在这里明确一下: 映射类型: Python>3.2中,collections.abc模块有Mapping和MutableMapping两个抽象基类(Python2.6~3 ...

  3. python之路---面向对象编程(一)

    一.设计思想的发展 面向机器(代码复杂,效率低,学习成本高,开发周期长)-------->面向过程(扩展性差,不适用多变的需求改变)----------->面向对象(扩展性好,但是可控性差 ...

  4. css样式 + 特殊符号

    color控制字体颜色 十六进制值 #cc0066: font-size控制字体大小 单位 px / % / em / rem:像素 / 相对于父级元素 / 取决自己使用字体大小 / 取决于根元素ht ...

  5. python全栈开发笔记----基本数据类型---列表List

    #list 是 类 ,列表 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. Python有6个序列的内置类型,但 ...

  6. 第一章02: 常用的DOS命令

    win+R=命令框 +输入CMD ,进入命令行.或者控制台 DOS命令如下: cd命令 1. CD.. = 返回上级目录 2. cd\ = 直接退到根目录 3.cd (地址)= 直接到指定文件 切盘符 ...

  7. LINUX 录制屏幕制作gif动态图工具peek

    sudo add-apt-repository ppa:peek-developers/stable sudo apt update sudo apt install peek linux 压缩工具改 ...

  8. 2017-9-3模拟赛T1 卡片(card)

    题目 [题目描述] lrb 喜欢玩卡牌.他手上现在有n张牌,每张牌的颜色为红绿蓝中的一种.现在他有两种操作.一是可以将两张任意位置的不同色的牌换成一张第三种颜色的牌:二是可以将任意位置的两张相同颜色的 ...

  9. CDMA码片序列问题

    要想知道到底是怎么算的 建议看见这篇博客的任何一位去先看一下这篇博客:https://blog.csdn.net/dog250/article/details/6420427 在CDMA中.每一个比特 ...

  10. 【oracle入门】数据完整性约束

    数据的完整性约束是对数据描述的某种约束条件,关系型数据模型中可以有三类完整性约束:实体完整性.参照完整性和用户定义的完整性. 实体完整性Entity Integrity 一个基本关系通过对应显示世界的 ...