zoukankan      html  css  js  c++  java
  • JavaScript——函数定义和调用

    1、定义函数

    定义方式一

    绝对值函数

    function abs(x){
        if(x>=0){
            return x;
        }else{
            return -x;
        }
    }
    

    上述abs()函数的定义如下:

    • function指出这是一个函数定义;
    • abs是函数的名称;
    • (x)括号内列出函数的参数,多个参数以,分隔;
    • { ... }之间的代码是函数体,可以包含若干语句,甚至可以没有任何语句。

    注意:

    函数体内部的语句在执行时,一旦执行到return时,函数就执行完毕,并将结果返回。因此,函数内部通过条件判断和循环可以实现非常复杂的逻辑。

    如果没有return语句,函数执行完毕后也会返回结果,只是结果为undefined

    定义方式二

    var abs = function(x){
        if(x>=0){
            return x;
        }else{
            return -x;
        }
    };
    

    注意:

    在这种方式下,function (x) { ... }是一个匿名函数,它没有函数名。但是,这个匿名函数赋值给了变量abs,所以,通过变量abs就可以调用该函数。

    上述两种定义完全等价,注意第二种方式按照完整语法需要在函数体末尾加一个;,表示赋值语句结束。

    2、调用函数

    调用函数时,按顺序传入参数即可

    abs(10)  //返回10
    abs(-10) //返回9
    

    参数问题:

    1. 由于JavaScript允许传入任意个参数而不影响调用,因此传入的参数比定义的参数多也没有问题,虽然函数内部并不需要这些参数:
    abs(10, 'blablabla'); // 返回10
    abs(-9, 'haha', 'hehe', null); // 返回9
    
    1. 传入的参数比定义的少也没有问题:
    abs(); // 返回NaN
    //此时abs(x)函数的参数x将收到undefined,计算结果为NaN。
    
    1. 要避免收到undefined,可以对参数进行检查:
    function abs(x) {
        if (typeof x !== 'number') {
            throw 'Not a number';
        }
        if (x >= 0) {
            return x;
        } else {
            return -x;
        }
    }
    

    3、arguments

    arguments是一个JS免费赠送的关键字;代表,传递进来的所有的参数,是一个数组!

    var abs = function(x){
    
        console.log("x="+x);
    
        for (var i = 0; i<arguments.length;i++){
            console.log(arguments[i]);
        }
        if(x>=0){
            return x;
        }else{
            return -x;
        }
    }
    
    1. 利用arguments,你可以获得调用者传入的所有参数。也就是说,即使函数不定义任何参数,还是可以拿到参数的值:
    function abs() {
        if (arguments.length === 0) {
            return 0;
        }
        var x = arguments[0];
        return x >= 0 ? x : -x;
    }
    
    abs(); // 0
    abs(10); // 10
    abs(-9); // 9
    
    1. arguments最常用于判断传入参数的个数。你可能会看到这样的写法:
    // abs(a[, b], c)
    // 接收2~3个参数,b是可选参数,如果只传2个参数,b默认为null:
    function abs(a, b, c) {
        if (arguments.length === 2) {
            // 实际拿到的参数是a和b,c为undefined
            c = b; // 把b赋给c
            b = null; // b变为默认值
        }
        // ...
    }
    

    4、rest

    ES6引入的新特性,获取除了已经定义的参数之外的所有参数!

    旧版本写法:

    function aaa(a,b) {
        console.log("a=>"+a);
        console.log("b=>"+b);
    if (arguments.length>2){
        for (var i = 2; i<arguments.length;i++){
    		//。。。。
        } 
    } 
    }
    

    ES6 引入的新特性,获取除了已经定义的参数之外的所有参数~ ….

    function aaa(a,b,...rest) {
        console.log("a="+a);
        console.log("b="+b);
        console.log(rest);
    }
    
    aaa(1, 2, 3, 4, 5);
    // 结果:
    // a = 1
    // b = 2
    // Array [ 3, 4, 5 ]
    
    aaa(1)
    // a = 1
    // b = undefined
    // Array []
    

    注意:

    • rest 参数只能写在最后面,必须用 … 标识。

    • 因为rest参数是ES6新标准,所以你需要测试一下浏览器是否支持。请用rest参数编写一个sum()函数,接收任意个参数并返回它们的和:

    'use strict';
    function sum(...rest) {
       ???
    }
    

    5、return

    JavaScript引擎有一个在行末自动添加分号的机制,所以要注意return的用法

    function foo() {
        return { name: 'foo' };
    }
    
    foo(); // { name: 'foo' }
    

    如果把return语句拆成两行:

    function foo() {
        return
            { name: 'foo' };
    }
    
    foo(); // undefined
    

    问题:为什么会undefined?

    由于JavaScript引擎有一个在行末自动添加分号的机制,上面的代码实际上变成了:

    function foo() {
        return; // 自动添加了分号,相当于return undefined;
            { name: 'foo' }; // 这行语句已经没法执行到了
    }
    

    所以正确多行写法是:

    function foo() {
        return { // 这里不会自动加分号,因为{表示语句尚未结束
            name: 'foo'
        };
    }
    
  • 相关阅读:
    php7.1安装
    nginx 的限制连接模块limit_zone与limit_req_zone
    selinux导致docker启动失败
    docker学习笔记
    kvm虚拟机
    ZooKeeper在线迁移
    启动EMQ(emqtt)时报错找不到libsctp.so.1
    Linux Samba服务主配文件smb.conf中文详解
    python-day7-字符串类型的内置方法
    python-day7-数字类型的内置方法
  • 原文地址:https://www.cnblogs.com/godles/p/12195983.html
Copyright © 2011-2022 走看看