递归:在函数的内部调用自己,如果是匿名函数,使用arguments.callee

作用域链:闭包

(就是把函数内部的变量通过某一种方式可以在函数外部使用,即一个函数就会产生自己的一个闭包空间)

原型的本质就是一个对象,

作用域链:由上依次向下进行的访问,里面存储的是自己的一个作用域,AO或GO,本来就是一个对象

原型:它是一个对象,它这个对象存在在某一个上面,从下往上进行访问

prototype(原型)是function的一个属性,它里面定义了这个构造函数(专门制造对象)产生对象的公共祖先

name

length

arguments函数内部

portotype原型

__proto__是对象的属性,这个属性是属于隐藏的属性,只能通过prototype进行修改

Object.prototype 可以说是大部分对象的最终原型,只有一种特殊情况,如果排除,是可以的

f1属于函数的声明,最常见的函数定义方式,f2实际上是一个匿名函数,把这个匿名函数赋值给了f2,属于函数表达式,f3不常见,但也是一种函数对象。

Function 是JS自带的对象,f1,f2 在创建的时候,JS会自动通过 new Function() 的方式来构建这些对象,因此,这三个对象都是通过 new Function() 创建的。

在 Javascript 中创建对象有两种方式:对象字面量和使用new表达式,o1和o2的创建恰好对应了这两种方式,重点讲一下o3, 如果用Java和C#的思路来理解的话,o3是f1的实例对象,o3和f1是同一类型,至少我以前这么认为,其实不然...

怎么理解呢? 很简单,看 o3 是不是通过 new Function 产生的,显然不是,既然不是函数对象,那就是普通对象 。

通过对函数对象和普通对象的简单理解之后,我们再来了解一下 Javascript 中的原型和原型链:

在 JS 中,每当创建一个函数对象 f1 时,该对象中都会内置一些属性,其中包括 prototype 和 __proto__, prototype 即原型对象,它记录着f1的一些属性和方法。

需要注意的是,prototype 对 f1 是不可见的,也就是说,f1 不会查找 prototype 中的属性和方法。

posted on 2018-12-20 20:08  啦啦啦12345  阅读(179)  评论(0编辑  收藏  举报