javascript面向对象——constructor属性(构造函数属性)

来源:互联网 发布:2017淘宝首页怎么装修 编辑:程序博客网 时间:2024/06/06 18:13
什么是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、它是实例化对象的属性。
从上面的例子中我们也能推断出上面的两条答案是成立的。
阅读全文
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 宝宝三岁说话口齿不清怎么办 b超宝宝腿短怎么办 两岁宝宝学说话口吃怎么办 两岁宝宝说话少怎么办 三岁宝宝说话少怎么办 快4岁不会说话怎么办 宝宝2岁半不爱说话怎么办 两岁半宝宝注意力不集中怎么办 中国出生的外籍小孩怎么办签证 中国人入外籍后国内财产怎么办 中国人入外籍后国内资产怎么办 小孩去美国上小学怎么办 咳嗽震的胸口疼怎么办 高中孩子对手机着迷怎么办 小孩不肯读书沉迷游戏怎么办 小孩沉迷吃鸡游戏怎么办 高一数学成绩差怎么办 小孩子学数学用手指算怎么办 孩子d和b分不清怎么办 和家人走散后怎么办幼儿教案 小孩胃口不好不爱吃饭怎么办 幼儿园孩子学习记不住怎么办 幼儿园小孩数字记不住怎么办 大班教案走丢了怎么办 ppt加视频反了怎么办 拔罐之后背疼怎么办 拔完火罐后背疼怎么办 打印机红色的口堵了怎么办 打印机红色复印不出来怎么办 打印机加错颜色墨水怎么办 中班安全教案脚扭伤了怎么办 中班脚扭伤了怎么办教案 中班安全脚扭伤了怎么办 中班安全脚扭伤了怎么办反思 走丢了怎么办教案反思 汽车后轱辘不转怎么办 走丢了怎么办社会教案 小老鼠搬鸡蛋鸡蛋太大怎么办 小班走丢了怎么办教案 小班走丢了怎么办反思 房屋外墙漏水物业不管怎么办