进阶三

作者: 饥人谷_流水 | 来源:发表于2017-05-10 23:36 被阅读0次

    1. 函数声明和函数表达式有什么区别

    函数声明:function functionName(){}
    函数表达式:var fn = function(){}
    函数声明会提前,函数表达式可以省略标识符(函数名)。

    2. 什么是变量的声明前置?什么是函数的声明前置

    变量的声明前置并不会对变量进行赋值

        console.log(a);
        var a = 3;
    

    等价于

      var a;
      console.log(a);//输出结果为undefined
      var a = 3;
    

    函数的声明前置

      fn(1)
      function fn(a){
         console.log(a);
     }
    

    输出的结果为1;因为function fn(a){...}的整个函数已经提前到了fn(1)之前声明了。

    3. arguments 是什么

    arguments是一个类数组对象。代表传给一个function的参数列表。
      arguments对象是函数内部的本地变量;arguments 已经不再是函数的属性了。可以在函数内部通过使用 arguments 对象来获取函数的所有参数。这个对象为传递给函数的每个参数建立一个条目,条目的索引号从0开始。它包括了函所要调用的参数。object对象。类数组。

    4. 函数的"重载"怎样实现

    在JS中,没有重载。同名函数会覆盖。但是js可以通过在函数内部对传入参数进行判断来达到重载的目的。

    function fn(name,age,sex) {

    0
    if (name) {
    console.log(name);
    }
    if (age) {
    console.log(age);
    }
    if (sex){
    console.log(sex);
    }
    }
    fn('luoqian');
    fn('luoqian',21);
    fn('luoqian',21,'female');

    5. 立即执行函数表达式是什么?有什么作用

    立即执行函数表达式是什么?有什么作用

    (function(){
    var a = 1;
    })()

    作用: 隔离作用域。

    立即执行函数能够立即执行,这样可以做到隔离作用域,避免变量污染全局。

    6. 求n!,用递归来实现

     function fn(n){
        if(n === 1 || n===0){
          return 1}
        else{
        return n*fn(n -1);
        }
     }
     fn(10);
    

    7. 以下代码输出什么?

    function getInfo(name, age, sex){
        console.log('name:',name);//输出name: 对应参数
        console.log('age:', age);//输出age: 对应参数
        console.log('sex:', sex);//输出sex: 对应参数
        console.log(arguments);//获取所有输入的参数,按照数组方式输出
        arguments[0] = 'valley';//改变第一个参数
        console.log('name', name);//输出改变后 name:对应参数
    }
    getInfo('饥人谷', 2, '男');//调用函数
    getInfo('小谷', 3);
    getInfo('男');
    

    函数按照自上而下顺序执行,如果没有传递对应参数,则直接输出undefined

    输出结果为

    name:饥人谷 age: 2 sex: 男 [ 饥人谷, 2 ,男] name:valley

    name:小谷 age: 3 sex: undefined [ 小姑, 3] name:valley

    name:男 age: undefined sex: undefined [ 男] name:valley

    8. 写一个函数,返回参数的平方和?

      function sumOfSquares(){
        var sum=0;
        for(var i=0;i<arguments.length;i++){
            sum+=arguments[i]*arguments[i];
        }
        console.log(sum);
    }
     var result = sumOfSquares(2,3,4)
     var result2 = sumOfSquares(1,3)
     console.log(result)  //29
     console.log(result)  //10
    

    9. 如下代码的输出?为什么

    console.log(a);//undefined   a 只是提前声明但没有被赋值
    var a = 1;
    console.log(b);//b is not defined  b没有被声明
    

    10. 如下代码的输出?为什么

    sayName('world');
    sayAge(10);
    function sayName(name){
        console.log('hello ', name);
    }
    var sayAge = function(age){
        console.log(age);
    };
    

    结果为:

    hello world
    sayAge is not a function 因为函数表达式不会前置。

    11. 如下代码输出什么? 写出作用域链查找过程伪代码

    var x = 10
    bar() 
    function foo() {
      console.log(x)
    }
    function bar(){
      var x = 30
      foo()
    }
    
    /*
    1.
      globalContext = {
        AO:{
            x:10
            foo:function
            bar:function
        },
    Scope:null
    }
    foo.[[scope]] = globalContext.AO
    bar.[[scope]] = globalContext.AO
    
    2.调用bar()
    barContext = {
        AO:{
            x:30
        },
        Scope:bar.[[scope]] = globalContext.AO
    }
    x变成30
    
    3.调用foo()
    fooContext = {
        AO:{},
        Scope:foo.[[scope]] = globalContext.AO
    }
    输出10
    

    12. 如下代码输出什么? 写出作用域链查找过程伪代码

    var x = 10;
    bar() 
    function bar(){
      var x = 30;
      function foo(){
        console.log(x) 
      }
      foo();
    }   
    
      /*   
       1.
          globalContext = {
        AO:{
            x:10
            bar:function
        },
        Scope:null
    }
    bar.[[scope]] = globalContext.AO
    2.调用bar()
    barContext = {
        AO:{
          x:30
        },
        Scope:bar.[[scope]] // globalContext.AO
    }
    foo.[[scope]] = barContext.AO
    3.调用foo()
    fooContext = {
        AO:{},
        scope:foo.[[scope]]
    }
    输出结果为30
    */
    

    13.以下代码输出什么? 写出作用域链的查找过程伪代码

    var x = 10;
    bar() 
    function bar(){
      var x = 30;
      (function (){
        console.log(x)
      })()
    }
     */
    
    /*1.
    globalContext = {
        AO:{
            x:10
            bar:function
        },
        Scope:null
    }
    bar.[[scope]] = globalContext.AO
    2.调用bar()
    barContext = {
        AO:{
            x:30
            function
        },
        Scope:bar.[[scope]] //globalContext.AO
    }
    function.[[scope]] = barContext.AO
    3.调用立即执行函数
    functionContext = {
        AO:{},
        Scope:function.[[scope]]//barContext.AO
    }
    结果为30*/
    

    14.以下代码输出什么? 写出作用域链查找过程伪代码

    var a = 1;
    function fn(){
    console.log(a)
    var a = 5
    console.log(a)
    a++
    var a
    fn3()
    fn2()
    console.log(a)
    function fn2(){
    console.log(a)
    a = 20
      }
    }
    function fn3(){
     console.log(a)
    a = 200
    }
    fn()
    console.log(a)
    
    /*
    1.
    globalContext = {
        AO:{
            a:1
            fn:function
            fn3:function
        },
        Scope:null
    }
    fn.[[scope]] = globalContext.AO
    fn3.[[scope]] = globalContext.AO
    
    2.调用fn()
    fnContext = {
        AO:{
            a:undefined
            fn2:function
        },
        Scope:fn.[[scope]] // globalContext.AO
    }
    fn2.[[scope]] = fnContext.AO
    
    3.
    fn3Context = {
        AO:{
            a:200
        },
        Scope:fn3Context.[[scope]]//globalContext.AO
    }
    fn2ConText = {
        AO:{
            a:20
        },
        Scope:fn2ConText.[[scope]]//fnContext.AO
    }
    
    开始执行
    console.log(a)//undefined 打印
    var a = 5//fnContext中a变成5
    console.log(a)//5
    a++//fnContext.AO中a变为6
    调用fn3()
    fn3()中
    console.log(a)//globalContext.AO中的a值为1,打印
    a = 200//globalContext.AO中的a变为200
    调用fn2()
    console.log(a);//fnContext.AO中的a值为6,打印
    a = 20;//fnContext.AO中的a变为20
    继续执行fn()
    console.log(a)//fnContext.AO中的a值为20,打印
    fn()结束
    console.log(a)//globalContext.AO中a值为200,打印
    
    //输出的结果 undefined 5 1 6 20 200
    */

    相关文章

      网友评论

          本文标题:进阶三

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