JavaScript原型实例分析


这篇文章主要讲解了“JavaScript原型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原型实例分析”吧!JS中声明函数的三种方式1.function 函数名(){}声明2.匿名函数声明 var foo = function () {}3.构造函数声明 var foo = new Function(“形参1″,”形参2″,”形参3”)。任何函数都可以用new Function 来创建当我们用函数去创建对象时,如下Fun就是构造函数。fn()是实例对象并且知道:1. 任何函数,上面的fn fn1 fn2 fn2都是Fun的实例,而Fun也是构造函数Function的实例,Function是JS内置的对象。2. 看到上面一段代码,Fun.prototype指代/指向的是原型(对象,后面直接称为原型)。我们接下来看第二个对象:知道以下知识点:1. 只要用new关键字 + 构造函数生成的对象,就是实例对象2. 即便没有用new + 关键字,而是用比如字面量创建对象,或者是函数直接 function 函数名() {} 这样声明,生成的也是实例对象,如上面代码 。3.记住重要的知识点:所有的实例对象都有__proto__属性,甚至可以去掉实例,改为所有的对象都有__proto__属性。 4. 知道如下代码中,fn 是构造函数Fun的实例对象,并且Fun也是构造函数Function的实例对象。得出的结论是:1. fn实例对象的__proto__属性指向构造函数Fun的属性prototype【原型】2. 而Fun的实例对象的__proto__属性也指向构造函数的Function的prototype【原型】 备注:在这里,prototype既是Fun的属性,而Fun.prototype也是最终的一个地方,目的地,这个目的地叫作原型对象。第一个console对应下图的序号1,第二个console对应下图的序号4知道知识点:1. 所有的函数都有一个原型对象。比如函数Function,它有原型对象Function.prototype。也有说法叫Function.prototype 为 函数Function的伴生对象,意思是函数Function一创建,就有一个陪伴它一起创建的对象叫Function.prototype。而Function自己的身上,又有一个属性叫作prototype,这个属性指向了它的伴生对象。2. 函数的原型对象身上有一个属性,叫作,constructor,它能够指回构造函数。就好像,构造函数Function通过属性prototype指向了原型对象Function.prototype,而原型对象Function.prototype通过自身的constructor属性指回去。比如下面的,可以自行验证。3. 函数的原型对象身上还有一个属性,叫作__proto__属性。浏览器打印出来现在长这样,[[Prototype]]:Object原型当中的__proto__指向父类的原型对象prototype,比如下面的代码下面的意思是函数Person的p免费云主机域名rototype,这是一个原型对象,它的__proto__属性指向Object父类的prototype,Function也是类似。为什么是这样?因为既然Person.prototypeFunction.prototype都叫作原型对象,都是对象,那么本质都是通过new Object创建的,都是构造函数Object的实例,因此它们也是实例对象,身上也有__proto__属性指向Object父类。对应下图的序号3记住:Object是各个对象的根1. 记住这个属性是函数独有的下面的代码,fn有prototype,Fun构造函数有prototype,Function下面没写出来,但是也有prototype。看代码注意:1. 上面的fn55是通过new Function创建的一个函数,2. 函数有prototype3. 同时fn55也是通过new + Function 创建的一个实例对象, 因此也有__proto__,指向Function构造函数的prototype看下面代码注意上面代码:1. 上面是通过new + Fun 创建了一个实例对象2. 这里是通过构造函数Fun创建了一个对象fnn,而fnn并不是函数,因此并没有prototype原型对象1. 记得万物都是对象 因此万物都有__proto__2. 构造函数的创建的实例对象,有__proto__,指向构造函数的prototype3. 函数实例有__proto__,也指向构造函数Function4. function Object和 function Function 都是构造函数Function的实例,因此也有__proto__5. 原型对象也是对象,因此也有__proto__每一个原型对象身上,才有constructor属性一些更加复杂的情况1. obj.__proto__指向Object.prototype2. Object.prototype.constructor就是指向Object本身备注:Object也是构造函数也是Function的实例对象 因此下面Object也有__proto__3. Object.__proto__指向Function.prototype4. Function.prototype.__proto__指向什么?这个就是[原型对象也是对象]原型对象的__proto__指向什么?指向的是父类的prototype也就是Object.prototype5. Object.prototype指向什么,就是原型链的终点null 可以下去自行验证原型链就是__proto__的终点感谢各位的阅读,以上就是“JavaScript原型实例分析”的内容了,经过本文的学习后,相信大家对JavaScript原型实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是百云主机,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: CSS的背景知识点有哪些

本篇内容主要讲解“CSS的背景知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS的背景知识点有哪些”吧!CSS background属性是以下属性的简写。背景剪辑,背景颜色,背景图像,背景来源,背景位…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 09/26 20:52
Next 09/26 20:56

相关推荐