美文网首页
昨天js变量提升题面试题(答案及解释)

昨天js变量提升题面试题(答案及解释)

作者: 锋享前端 | 来源:发表于2018-09-21 15:16 被阅读0次

昨天总结的针对js变量提升这个知识点总结了9道题,下面是给大家做出的答案和解释:

    // js代码解析原则
    // 首先js引擎在读取js代码时会进行两个步骤,第一个步骤是解释,第二个步骤是执行。 
    // 所谓解释就是会先通篇扫描所有的Js代码,然后把所有声明提升到顶端,第二步是执行,执行就是操作一类的。
    // 例子1:
    console.log(a); //输出结果 undefined
    var a = 10;
    //  以上代码输出 undefined
    //  原因: 变量提升( 把变量声明提升到当前执行环境的最顶端)
    //  上段代码相当于:
    var a;
    console.log(a); //由于未赋值 所以输出undefined 
    a = 10;

    // 例2:
    foo();

    function foo() {
        console.log("aaa");
    }
    //  结果输出: aaa 
    // 原理:函数声明提升 (函数声明提升直接把整个函数提到执行环境的最顶端)
    // 
    // 相当于:
    function foo() {
        console.log("aaa");
    }

    foo();
    //  变量提升只提升函数名 而函数提升会提升整个函数题 注意:函数提升在变量提升上面。
    // 
    // 例3:
    foo();
    var foo = function () {
        console.log("aaa");
    }

    // 运行结果是: foo is not a function
    // 
    // 原因: 还是进行了变量提升 
    // 相当于:
    var foo;
    console.log(foo); //undefined
    foo(); //foo is not a function
    foo = function () {
        console.log("aaa");
    }
    //  上面代码输出undefined 是因为变量提升后并没有赋值因此输出undefined
    // 
    // 输出foo is not a function 原因是:js解析遇到 foo()时会默认当做函数来解析
    // 
    // 例4:
    console.log(foo);
    var foo = 10;
    console.log(foo);

    function foo() {
        console.log(10);
    }
    console.log(foo);
    // 输出结果:

    function () { //67行输出
        console.log(10);
    }
    10 //69行输出
    10 //72行输出/
    //  原理: 
    // 相当于:
    function foo() {
        console.log(10);
    }
    var foo;
    console.log(foo);
    foo = 10;
    console.log(foo);
    console.log(foo);
    // 注意: 函数提升在变量提升上面,第一个console.log(foo);为什么会输出函数题呢,原因在于 var foo; 并未有赋值只是声明,因此他会调用上面的值
    // 
    // 例如:
    var b = 10;
    b = 10;
    console.log(b); //10 输出上一个值不会输出undefined
    // 但是更改后:
    var b = 10;
    b = 20;
    console.log(b); //20 输出20不是上一个值

总结:

关于变量提升,一定要注意细心思考一下,还有就是要牢记,函数提升在变量提升之上;
怎么样是不是感觉对js的理解和变量一样提升了呢?

相关文章

  • 昨天js变量提升题面试题(答案及解释)

    昨天总结的针对js变量提升这个知识点总结了9道题,下面是给大家做出的答案和解释: 总结: 关于变量提升,一定要注意...

  • 第11题- 变量提升和函数提升

    面试题目(腾讯): 下面题目输出结果是什么? 答案解析: 这道题目主要考察JS的变量提升和函数提升相关的知识点 1...

  • 变量声明提升

    变量声明提升是JS中一个基础的问题,同时也是对JS词法作用域认识的一个提升。在JS面试题中,关于变量声明提升的问题...

  • iOS高级面试之面试题集

    1.将近100题及答案,分析的较为透彻 iOS面试题及答案 2. 近百题试题及答案,附上实例 【2018年最新】 ...

  • 帮大家总结一下js变量提升的面试题

    帮大家总结一篇面试题,针对js变量提升这个知识点总结了9道题,如果你都能做出来并且能做对的话变量提升这一块就没问题...

  • 变量提升

    参考信息:https://www.runoob.com/js/js-hoisting.html 对变量提升的解释:...

  • var/let/const的区别

    var有变量提升,let/const没有变量提升。原因是:var(function也是)在js进行解释扫描的时候,...

  • 一道面试题引发的"血案"

    题目及答案: 此题涉及的知识点众多,包括变量定义提升、this指针指向、运算符优先级、原型、继承、全局变量污染、对...

  • 前端资料

    ES6新数据类型 Symbol . js变量提升函数提升 js this js 原型及原型链理解 new做了什么 ...

  • 值得一看的文章--面试可能用得到

    js系列 js面试题 : 本文全面考察了: 变量名提升、this作用域链、运算符优先级、全局变量名污染已经对象属性...

网友评论

      本文标题:昨天js变量提升题面试题(答案及解释)

      本文链接:https://www.haomeiwen.com/subject/uzoanftx.html