美文网首页
JS入门之函数

JS入门之函数

作者: 赎_a | 来源:发表于2019-07-31 15:21 被阅读0次

    函数

    函数定义: 函数可以封装任意多条语句,可以在任何地方或时候调用执行

    一、创建函数的方法:

    // 第一种: 函数声明

    function 函数名() {
        // 执行代码
    }
    

    // 第二种函数表达式

    var fn = function () {
        // 执行代码
    }
    

    // 第三种: 实例化函数

    var fn = new Function('执行代码');
    

    // 第四种:匿名函数也叫自执行函数、拉姆达函数
    在这个命名空间内定义的变量都不会污染到全局命名空间

    (function () {
        // 执行代码
    
    })()
    

    // 调用函数
    fn();

    二、函数声明与函数表达式的区别

    1. 解析器会率先读取函数声明,并使其在执行任何代码之前可用
    2. 函数表达式,则必须等到解析器执行到它所在的代码行,才会真正被解释执行
    3. 本质是变量与函数的提升

    三、函数无重载

    概念: 在ECMAScript中定义了两个函数名相同的函数,则名字只属于后定义的函数(后面定义的函数会覆盖前面定义的函数)

    四、函数的参数

    1. 形参

    形式上的参数: 命名的参数只提供的便利,但不是必需的
    形参个数: 函数名.length

    function fn(x, y, z) {
    //   x,y,z为形参
    console.log(x, y, z); // 1, 2 undefined
    }
    fn(1, 2);
     //  1, 2 是实参.
    

    2. 实参

    实际的参数: 调用函数时传入有值的参数
    实参的个数: 实参集合中(argument.length);

    3. arguments

    arguments对象:实参的类数组,从而获取传递给函数的每一个参数
    arguments对象的长度是由传入的参数个数决定的,不是由定义函数时的命名参数的个数决定的
    也有length属性,代表传入了几个参数
    arguments.callee: 指的是当前执行的函数

    4. return 返回值

    1. 当一个函数没有返回值时候,默认返回undefined
    2. 当使用 -> return 反馈信息;
    3. return 之后的语句不会执行,return终止了函数执行

    五、函数内外(局部和全局)变量及区别

    局部变量:

    在其内部定义的变量为局部变量也就是局部作用域下声明的变量
    只能在内部访问
    局部作用域:起作用的区域

    全局变量:

    在函数体外,整个执行环境为window下定义的变量为全局变量也就是全局作用域下声明的变量
    可在全局及局部均可访问到
    全局作用域:起作用的区域

    六、 变量提升和函数体提升

    在js代码执行之前:解析器会将变量名以及函数声明的函数体提升到最顶端

    1. 函数提升:

    如果函数名相同的两个函数: 前面函数会覆盖后面的函数 (导致我们的函数无重载的概念)

    1. 函数名和变量名相同:函数优先覆盖变量

    相关文章

      网友评论

          本文标题:JS入门之函数

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