您好,欢迎来到爱玩科技网。
搜索
您的当前位置:首页js函数需要掌握的知识

js函数需要掌握的知识

来源:爱玩科技网


在这里函数声明和函数表达式有什么区别呢?
解析器在向执行环境中加载数据的时候,对函数声明和函数表达式是不一样的。解析器首先会读取函数声明,并且使得这段函数声明代码在任何代码之前都可调用。这就是我们平时所说的函数声明提升。函数表达式不一样,他必须等到函数解析器执行到他所在的代码块的时候,才会被真正的执行。比较下面2个例子

console.log(sum(10,10));

function sum(n1,n2){
 return n1+n2;
}

以上代码会正常执行

再看!

console.log(sum(10,10));

var sum=function(n1,n2){
 return n1+n2;
}

以上执行器就会报错!

2.函数没有重载

如果声明了2个同名函数,结果是后面的函数覆盖了前面的函数。

function sun(a){
 return a+100;
}
function sun(a){
 return a+200;
}

var result=sum(2)//202

3.函数的内部属性

  • 包括this,arguments

    具体不再叙述了

  • 4.函数的属性和方法

  • 函数有2个属性,length和prototype

  • length表示函数希望接收命名参数的个数。

    function a(name){
     //todo
    }
    function b(name,age){
     //todo
    }
    function c(){
     //todo
    }
    
    a.length //1
    b.length //2
    c.length //0

    prototype属性对于引用类型来说很重要,会有专门讲解,此处不再这赘述。

  • 每个函数都包含2个非继承的方法 apply,call

  • 这两个方法的用途都是在特定的作用域中调用函数,其实就是设置函数体内的this指代的值。

    首先。apply()方法接收2个参数,一个是函数运行的作用域,另一个是参数数组,第二个参数可以是数组的实例,也可以是arguments.

    function sum(num1,num2){
     return num1+num2;
    }
    
    function test1(a,b){
     return sum.apply(this,arguments);
    }
    
    function test2(c,d){
     return sum.apply(this.[c,d]);
    }
    
    console.log(test1(1,1)) //2
    
    console.log(test2(1,1)) //2

    call方法和apply方法没有多大的区别。区别就是call方法的第二个参数必须得传递的参数一个个列举出来。

    使用call和apply来扩充作用域最大的好处就是对象不和任何方法耦合。

    相关推荐:

    JS函数实例详解

    js函数的按值传递参数

    js函数的调用及有关隐式参数arguments和this的问题

    Copyright © 2019- aiwanbo.com 版权所有 赣ICP备2024042808号-3

    违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

    本站由北京市万商天勤律师事务所王兴未律师提供法律服务