作用域链和原型链

来源:互联网 发布:sql视图和表的区别 编辑:程序博客网 时间:2024/06/09 22:54

作用域链:针对变量,比如说创建一个函数,函数里面又包含了一个函数,那么就有了三个作用域:全局作用域==>函数1作用域==>函数2作用域
作用域的特点: 先在自己的变量范围查找,若找不到,就沿着作用域往上找
例如:var a = 1;
function b(){
var a = 2;
function c(){
var a = 3;
console.log(a);
}
c();
}
b();
最后打印出来的是3,因为执行函数c()的时候它在自己的范围内找到了变量a所以就不会越上继续查找,如果在函数c()中没有找到则会继续向上找, 一直会找到全局变量a,这个查找的过程就叫作用域链。
注意:函数c的作用域包括函数b的作用域,也包括全局作用域
原型链:针对构造函数
例如先创建了一个函数,然后通过一个变量new了这个函数,那么这个被new出来的函数就会继承创建出来的那个函数的属性,然后如果我访问new出来的这个函数的某个属性,但是我并没有在这个new出来的函数中定义这个变量,那么它就会往上(向创建出它的函数中)查找,这个查找的过程就叫做原型链。

Object ==> 构造函数1 ==> 构造函数2

就和css中的继承一样,如果自身没有定义就会继承父元素的样式。

function a(){};
a.prototype.name = “追梦子”;
var b = new a();
console.log(b.name); //追梦子
b.name = “sss”
console.log(b.name); //sss

原创粉丝点击