- 浏览: 435106 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (377)
- Java (66)
- C++ (0)
- VC++ (0)
- .net (1)
- css (36)
- 数据库 (22)
- html (2)
- extjs (1)
- jpbm (0)
- javascript (31)
- 物资管理 (1)
- java基础 (5)
- C# (0)
- Android (56)
- window service (1)
- 其他 (2)
- Web服务器 (7)
- jbpm (1)
- eclipse (2)
- tomcat (3)
- java字符串与二进制的相互转化 (1)
- Oracle 数据库 (6)
- FreeMarker (8)
- 浏览器 (1)
- php (1)
- photoshop (6)
- spring (4)
- spring mvc (2)
- Acegi (1)
- webStorm 3.0 (4)
- Mongodb (8)
- mysql (9)
- 软件开发:需求分析 (1)
- 把Java程序作为Windows系统服务 (1)
- nodejs (4)
- json (1)
- 缓存 (1)
- J2ee (2)
- Flash报表 (1)
- MyEclipse+Maven+Tomcat (11)
- 生活 (1)
- Ubuntu (1)
- Bootstrap (1)
- jquery easy ui (2)
- 敏捷开发 (1)
- phone gap (1)
- rest (1)
- 移动开发 (22)
- Redis + Jedis + Spring (3)
- anroid (7)
- grunt 教程 (7)
- PhoneGap (2)
- sublime text (7)
- mariadb (1)
- linux (1)
- maven (2)
- jquery (1)
- ActiveMQ (1)
- LVS Nginx (1)
- nginx (6)
- ngnix (1)
- 爱因斯坦 (1)
- 天干地支 (1)
最新评论
-
muqingren:
...
Maven多模块布局实例详解 -
shutear:
解决了我的难题,谢谢分享!
Unable to load configuration. - action - file:/D:/studytool/apache-tomcat-6.0.16 -
702346318:
[img][/img][flash=200,200][/fla ...
CAS单点登录完整教程(上)【转】 -
liuguofeng:
PersonS631887934 写道学习中。。 有个问题想请 ...
js constructor属性 -
S631887934:
学习中。。 有个问题想请教楼主为什么要加上Person.pro ...
js constructor属性
constructor属性始终指向创建当前对象的构造函数。比如下面例子:
var arr = [1, 56, 34, 12]; // 等价于 var foo = new Array(1, 56, 34, 12); document.writeln(arr.constructor === Array);// true
在看下面的例子
var foo = new Function(); var Foo = function() { }; document.writeln(Foo.constructor === Function); // true // 由构造函数实例化一个obj对象 var obj = new Foo(); document.writeln(obj.constructor === Foo); // true // 将上面两段代码合起来,就得到下面的结论 document.writeln(obj.constructor.constructor === Function); // true
但是当constructor遇到prototype时,有趣的事情就发生了。 我们知道每个函数都有一个默认的属性prototype, 而这个prototype的constructor默认指向这个函数。如下例所示: Java代码 function Person(name) { this.name = name; }; Person.prototype.getName = function() { return this.name; }; var p = new Person("ZhangSan"); document.writeln(p.constructor === Person);// true document.writeln(Person.prototype.constructor === Person); // true // 将上两行代码合并就得到如下结果 document.writeln(p.constructor.prototype.constructor === Person); // true function Person(name) { this.name = name; }; Person.prototype.getName = function() { return this.name; }; var p = new Person("ZhangSan"); document.writeln(p.constructor === Person);// true document.writeln(Person.prototype.constructor === Person); // true // 将上两行代码合并就得到如下结果 document.writeln(p.constructor.prototype.constructor === Person); // true 当时当我们重新定义函数的prototype时(注意:和上例的区别,这里不是修改而是覆盖), constructor属性的行为就有点奇怪了,如下示例: Java代码 function Person(name) { this.name = name; }; Person.prototype = { getName: function() { return this.name; } }; var p = new Person("ZhangSan"); document.writeln(p.constructor === Person); // false document.writeln(Person.prototype.constructor === Person); // false document.writeln(p.constructor.prototype.constructor === Person); // false function Person(name) { this.name = name; }; Person.prototype = { getName: function() { return this.name; } }; var p = new Person("ZhangSan"); document.writeln(p.constructor === Person); // false document.writeln(Person.prototype.constructor === Person); // false document.writeln(p.constructor.prototype.constructor === Person); // false 为什么呢? 原来是因为覆盖Person.prototype时,等价于进行如下代码操作: Java代码 Person.prototype = new Object({ getName: function() { return this.name; } }); Person.prototype = new Object({ getName: function() { return this.name; } }); 而constructor属性始终指向创建自身的构造函数, 所以此时Person.prototype.constructor === Object,即是: Java代码 function Person(name) { this.name = name; }; Person.prototype = { getName: function() { return this.name; } }; var p = new Person("ZhangSan"); document.writeln(p.constructor === Object); // true document.writeln(Person.prototype.constructor === Object); // true document.writeln(p.constructor.prototype.constructor === Object); // true function Person(name) { this.name = name; }; Person.prototype = { getName: function() { return this.name; } }; var p = new Person("ZhangSan"); document.writeln(p.constructor === Object); // true document.writeln(Person.prototype.constructor === Object); // true document.writeln(p.constructor.prototype.constructor === Object); // true 怎么修正这种问题呢?方法也很简单,重新覆盖Person.prototype.constructor即可: Java代码 function Person(name) { this.name = name; }; Person.prototype = new Object({ getName: function() { return this.name; } }); Person.prototype.constructor = Person; // 如此也可以 /* Person.prototype = new Object({ constructor:Person, getName: function() { return this.name; } }); Person.prototype = { constructor:Person, getName: function() { return this.name; } }; */ var p = new Person("ZhangSan"); document.writeln(p.constructor === Person); // true document.writeln(Person.prototype.constructor === Person); // true document.writeln(p.constructor.prototype.constructor === Person); // true
评论
3 楼
liuguofeng
2012-05-23
Person
你去了解一下运算符,你就清楚了
S631887934 写道
学习中。。 有个问题想请教楼主
为什么要加上Person.prototype.constructor = Person;
除了让constructor重新指向Person外,如果不修改会对功能方面有什么其他影响吗?
为什么要加上Person.prototype.constructor = Person;
除了让constructor重新指向Person外,如果不修改会对功能方面有什么其他影响吗?
你去了解一下运算符,你就清楚了
2 楼
S631887934
2012-05-22
学习中。。 有个问题想请教楼主
为什么要加上Person.prototype.constructor = Person;
除了让constructor重新指向Person外,如果不修改会对功能方面有什么其他影响吗?
为什么要加上Person.prototype.constructor = Person;
除了让constructor重新指向Person外,如果不修改会对功能方面有什么其他影响吗?
1 楼
hhzhaoheng
2012-05-17
thanks for your code and your efforts
发表评论
-
Array.prototype.slice.call
2014-11-01 15:18 714在研究某个框架源码的时候,看到的。查了下资料,1.两个部分, ... -
深入理解jQuery插件开发
2014-11-01 12:17 456如果你看到这篇文章,我确信你毫无疑问会认为jQuery是一个 ... -
jquery 控制能输入数字和字母
2014-10-18 15:37 687内容",而"禁用输入法,获取剪切板的内 ... -
值得收藏的新jQuery插件
2014-09-25 22:39 6361) slideshow Really Simple S ... -
窗口大小 window.innerWidth 、window.innerHeight、document.documentElement.clientWidth、
2014-07-27 09:52 853/ Firefox、Chrome、Safari、Opera ... -
精选在线课程:前端开发入门、进阶与实战(中文系列)
2014-07-26 22:06 0在线教育的浪潮吸引了越来越多的网站加入,争相推出各种课程吸引 ... -
浏览器缓存机制
2014-07-26 13:19 628浏览器缓存机制,其实主要就是HTTP协议定义的缓存机制(如: ... -
JavaScript中双叹号“!!”作用
2014-07-25 23:20 460经常看到这样的例子: var a;var b=!!a; ... -
js中style,currentStyle和getComputedStyle的区别
2014-07-13 09:51 738<style> body{margin:0 a ... -
JS OffsetParent属性
2014-06-14 11:12 652offsetParent属性返回一个对象的引用,这个对象 ... -
javascript两行代码按指定格式输出日期时间
2014-05-11 14:33 620// <summary>// 格式化显示日期时间/ ... -
Js中sort()方法的用法
2012-10-12 11:25 1063关键字: sort, 排序方 ... -
网页常用特效整理
2012-04-21 17:37 9111.节日倒计时 < ... -
jquery validate自定义验证方法(转)
2012-03-30 10:55 1025// 身份证号码验证 jQuery.validator ... -
document.documentElement和document.body的区别
2012-03-13 12:00 780网页中获取滚动条卷去部分的高度,可以通过 document.b ... -
document.compatMode属性
2012-03-13 11:58 902document.compatMode用来判断当前浏览器采 ... -
js库建设方案
2012-03-13 11:58 1043前言: 自从互联网诞生之日起,JavaScript就成为 ... -
关于scrolltop 兼容 IE6/7/8, Safari,FF的方法
2012-03-13 11:57 21701、各浏览器下 scrollTop的差异IE6/7/8 ... -
IE内存泄露监测工具 sIEve介绍
2012-03-08 10:23 1243在IE下监控页面内存资 ... -
网站优化之Ajax优化及相关工具
2012-03-08 09:56 984web2.0大量的ajax的使用,提高了ui交互的效率,但 ...
相关推荐
JavaScript的constructor属性[文].pdf
javascript new后的constructor属性.docx
对象的constructor属性用于返回创建该对象的函数,也就是我们常说的构造函数,除了创建对象,构造函数(constructor) 还做了另一件有用的事情—自动为创建的新对象设置了原型对象(prototype object)
真正的原因是:一个对象的constructor是它的构造函数的prototype.constructor,而每一个函数都有一个prototype,默认情况下,这个prototype有一个constructor属性,指向的是它自己。 我觉得Javascript的设计本意是让...
prototype对象有constructor属性指向BB这个函数;所以alert(b.constructor==BB.prototype.constructor) //true 这里的“有了”的执行过程是先查看b有没有此属性让后去查看prototype里的属性值,不是简单的A=...
constructor属性始终指向创建当前对象的构造函数。比如下面例子:比如下面例子: 代码如下: // 等价于 var foo = new Array(1, 56, 34, 12); var arr = [1, 56, 34, 12]; console.log(arr.constructor === Array); /...
本文实例讲述了js核心基础之构造函数constructor用法。分享给大家供大家参考,具体如下: 在js中,可以利用构造函数来创建特定类型的对象,其中,有一些原生的构造函数,Object、Array、等等,所以,当type of ...
constructor 属性返回对创建此对象的数组函数的引用。本文给大家介绍JavaScript中的constructor ,需要的朋友参考下吧
一直没弄清楚JavaScript中的prototype和constructor属性,今天看了看书,总算有点眉目了
本文实例讲述了js构造函数constructor和原型prototype原理与用法。分享给大家供大家参考,具体如下: 所有引用类型(函数,数组,对象)都拥有__proto__属性(隐式原型) 所有函数拥有prototype属性(显式原型)(仅...
JavaScript中的几种继承方法示例 1.原型链继承 ...原型对象上有一个constructor属性,指向创建该对象的构造函数,该属性不可枚举。 var obj = {}; obj.__proto__ === Object.prototype; //true console
prototype 属性的功能: 所有JavaScript 内部对象都有只读的prototype 属性。可以为内部对象的原型添加功能,但该对象不能被赋予不同的原型。 然而,用户定义的对象可以被赋给新的原型。 constructor 属性的作用: ...
这里有一点需要注意的是,每个函数都有一个prototype属性,这个prototype的constructor指向这个函数,这个时候我们修改这个函数的prototype时,就发生了意外。如 function Person(name,age){ this.name = name; ...
构造器模式简单描述(看图): 构造器Constructor不能被继承,因此不能重写Overriding,但可以被重载...Javascript不支持类的情况下对象与Constructor,通过new关键字实例化一个对象,代码大概是这样的 funct
每个函数创建时默认带有一个prototype属性,其中包含一个constructor属性,和一个指向Object对象的隐藏属性__proto__。constructor属性的值为该函数的对象。在一个函数前面加上new来调用,则会创建一个隐藏连接到该...