zoukankan      html  css  js  c++  java
  • 函数(参数、重载)

      函数会在执行完return语句之后停止并立即退出,因此,位于return语句之后的任何代码都不会执行。

    严格模式对函数的限制

    • 不能把函数、参数命名为eval或arguments。
    • 不能出现两个命名参数同名的情况

    参数理解

    ECMAScript中的参数在内部是用一个数组来表示的。函数接收到的始终是这个数组,而不关心数组中包含多少个参数,即使没有参数也可以,也不在乎传进来的参数是什么数据类型。例如:定义的函数只接收两个参数,在调用这个函数时未必一定传递两个参数。

    arguments对象只是与数组类似(它并不是Array的实例),函数可以通过arguments对象来访问参数数组,从而获取传递给函数的每一个参数,即第一个参数是arguments[0],第二个参数是arguments[1],以此类推。使用length属性来确定传递进来多少个参数。如下:

    //函数
    function sayHi(name,msg){
        console.log('hello! '+name+','+msg);
    }
    
    //同样的使用arguments也可以实现
    function sayHi(){
     console.log('hello! '+arguments[0]+','+arguments[1]);
    }
    
    //调用时候,可以返回同样的结果
    sayHi('tom','how old are you today?'); //hello!tom,how old are you today?

    arguments的值永远与对应命名参数的值保持同步。如下:

    function doAdd(num1, num2) {
        arguments[1] = 10;    //将arguments[1]重写为10,因为arguments的值会自动反映到对应的命名参数,
    所以num2也被修改为10。但是它们的内存空间是独立的,但它们的值会同步。

    //如果只传入了一个参数,那么arguments[1]设置的值不会反映到命名参数中。因为arguments对象的长度是由传入的参数
    个数决定的,不是由定义函数时的命名参数的个数决定的。
    alert(arguments[0] + num2); } doAdd(10, 20); //20 doAdd(30, 20); //40

    没有传递值得命名参数将自动被赋予undefined值,就跟定义了变量但没有初始化是一样的。

    function add(a,b){
      return b;
    }
    add(1);//undefined
    add(1,2)//2

    关于重载

    ECMAScript没有函数签名【接收参数的类型和个数没影响】,所以函数重载没办法实现。

    利用arguments可以实现函数的重载效果,如下:

    //根据传递参数的个数来执行不同的逻辑
    function doAdd(){
       if(arguments.length==1){
            console.log(arguments[0]+10);
        }else if(arguments.length==2){
             console.log(arguments[0]+arguments[1]);
        }
    }
    
    //调用
    doAdd(10);    //20(执行if)
    doAdd(10,30);   //40(执行elseif)

    ECMAScript中没有函数重载,so如果存在两个同名的函数,则该名字只属于后定义的函数【即后定义的函数才有效】。

            function addSomeNumber(num){
                return num + 100;
            }
            
            function addSomeNumber(num) {
                return num + 200;
            }
            
            var result = addSomeNumber(100);    
            alert(result);   //300 

    js函数重载

  • 相关阅读:
    App测试从入门到精通之安装、卸载和运行测试
    App测试从入门到精通之App分类和场景操作系统
    一步到位带你入门Selenium
    MAMP和WAMP搭建Web环境,数据库,数据分布可视化
    爬虫 Http请求,urllib2获取数据,第三方库requests获取数据,BeautifulSoup处理数据,使用Chrome浏览器开发者工具显示检查网页源代码,json模块的dumps,loads,dump,load方法介绍
    Python 基本语法,文件读写,数据结构和类型
    python 数据工程 and 开发工具Sublime
    jieba user guide
    python各类项目模块记录
    python parse xml using DOM
  • 原文地址:https://www.cnblogs.com/lmjZone/p/7874070.html
Copyright © 2011-2022 走看看