zoukankan      html  css  js  c++  java
  • 【JS】----作用域链与原型链

    转https://www.cnblogs.com/pssp/p/5204324.html

    什么是作用域链,什么是原型链。

      作用域是针对变量的,比如我们创建了一个函数,函数里面又包含了一个函数,那么现在就有三个作用域

      全局作用域==>函数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中查找变量a,因为函数c是在函数b中创建的,也就是说函数c的作用域包括了函数b的作用域,当然也包括了全局作用域,但是函数b不能向函数c中查找变量,因为作用域只会向上查找。

    那么什么是原型链呢?

      原型链是针对构造函数的,比如我先创建了一个函数,然后通过一个变量new了这个函数,那么这个被new出来的函数就会继承创建出来的那个函数的属性,然后如果我访问new出来的这个函数的某个属性,但是我并没有在这个new出来的函数中定义这个变量,那么它就会往上(向创建出它的函数中)查找,这个查找的过程就叫做原型链。

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

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

    function a(){};
    a.prototype.name = "追梦子";
    var b = new a();
    console.log(b.name); //追梦子
  • 相关阅读:
    结对编程项目作业2-结对编项目设计文档
    20170914-构建之法:现代软件工程-阅读笔记
    课后作业-阅读任务-阅读提问-1
    GIT 的使用方法
    团队-井字棋-需求分析
    结对-贪吃蛇-需求分析
    python_基础_0
    Unix_07_文件系统高级操作_2
    Unix_06_文件系统高级操作_1
    Unix_05_文件系统高级操作_0
  • 原文地址:https://www.cnblogs.com/asenper/p/9933068.html
Copyright © 2011-2022 走看看