zoukankan      html  css  js  c++  java
  • JS函数参数

    1、实参数大于形参数:前几个参数相对应赋值,多余的忽略

    function say(name,message){
        console.log('Hello' + name + message);
    }
    
    say('World!','ByeBye!','World’);
    //控制台打印出:HelloWorld!ByeBye!

    2、实参数小于形参数:前几个参数对应赋值,不足的 undefined

    function say(name,message){
        console.log('Hello' + name + message);
    }
    
    say('World!’);
    //控制台打印出:HelloWorld!undefined

    注意:在JS中变量定义的时候,如果未给一个变量赋初值那么该变量的类型为 undefiend

    3.通过arguments 来实现函数参数的“调用”:

    function say(name, message){
          console.log('Hello' + arguments[0] + arguments[1]);
          console.log(arguments.length);
    }
    say('World!', 'ByeBye!’);

    也可以按下面写法

    function say(){
        console.log('Hello' + arguments[0] + arguments[1]);
    
        console.log(arguments.length);
    }
    
    say('World!', 'ByeBye!’);

    控制台打印效果都是一样的;即:HelloWorld!ByeBye!

    即:在这里你可以这样理解;当发生函数调用的时候,实参被保存在叫做arguments的“数组”当中;而arguments中对应下标的值在发生函数调用的时候始终与被调用函数的参数保持;

    内存分析:

    function say(name, message){
          console.log(arguments[1] == message);
          arguments[1] = 'World!';
          console.log(arguments[1] == message);
    }
    
    say('World!', 'ByeBye!’);//控制台打印:true;true;

    不过并不是说读取这两个值会访问相同的内存空间,他们的内存空间是独立的,arguments中的值不会发生改变,也就是参数的改变不会改变arguments中对应的值

    function say(name, message){
          console.log(arguments.length);
    }
    
    say('World!');//控制打印:1;

    arguments对象的长度是由传入的参数个数决定,不由定义函数的参数的个数决定。

    美好生活
  • 相关阅读:
    IO多路复用--epoll(待学习)
    网络信息检索
    TCP协议的客户端与服务器的通信过程
    UDP网络编程
    HDU_oj_2017 字符串统计
    HDU_oj_2016 数据的交换输出
    HDU_oj_2015 偶数求和
    HDU_oj_2014 评委会打分
    HDU_oj_2013 蟠桃记
    HDU_oj_2012 素数判定
  • 原文地址:https://www.cnblogs.com/ssbydk/p/10180051.html
Copyright © 2011-2022 走看看