详解JavaScript的形参,实参以及传参

文章目录

  • 前言
  • 一、参数是什么?
  • 二、形参和实参
    • 1.形参     
    • 2.实参
  • 三、传参
    • 1.参数传递的对应关系
    • 2.两个传参的例子  
  • 总结


前言

编程初学者在接触JavaScript这门语言时,很难搞懂里面的逻辑,这就会导致入门慢,入门难。这种难度一般主要集中在函数,变量这块,难点以函数之间的传参,嵌套为主。


一、参数是什么?

参数如果用官方话来描述,又有一大批人难以理解。在这里,我们用最直观的方式,看看什么叫参数。

详解JavaScript的形参,实参以及传参_第1张图片 

详解JavaScript的形参,实参以及传参_第2张图片 

我在项目代码块当中截图3张,并进行了标记。 以上三张截图里,红色方框内的就叫参数。


二、形参和实参

1.形参

形参:函数定义的时候,函数名后面括号里的 字母,或者数字

注意:函数可以没有参数,参数并不是函数必须的

eg1:没有形参的函数

function aa(){
			
		}

我们把上面的代码叫做    名字为aa的函数

eg2:有形参的函数

function bb(res){
			
		}

我们把上面的代码叫做   名字为bb的函数,并且形参为res

2.实参

实参:函数调用的时候,函数名后面括号里的字母,或者数字

eg3:没有实参的函数调用

aa();

我们把上面的代码叫做   aa函数调用

eg4:有实参的函数调用

bb(2);

我们把上面的代码叫做   aa函数调用,并且实参为2

值得一提的是,参数可以有多个。

		function aa(ad,ag,af,ak){           
			
		}
		
		aa(1,2,3,4);

上面的函数有4个形参,分别为ad,ag,af,ak

上面的函数调用了一次,实参有4个,分别为1,2,3,4


三、传参

1.参数传递的对应关系

function numberSum(a,z,c,v){
	console.log(a+z+c+v);
}
numberSum(1,3,5,7);	    //输出16
numberSum(1,2),         //输出NaN

翻译一下:

以上函数名字叫numberSum,形参有4个,分别为a,z,c,v

函数执行代码为a,z,c,v求和

函数调用一次,实参为1,3,5,7                    输出结果为16

含义:实参和形参一一对应关系,a=1,z=3,c=5,v=7 求和结果为1+3+5+7=16            

如果换种方式调用,实参为1,2                   输出结果为NaN

含义:实参和形参一一对应关系,a=1,z=2,c为undefined,v为undefined(未定义),求和结果为1+2+undefined+undefined = NaN

                       NaN不是一个数字,但是数据类型仍是number

                       可以使用console.log(typeof(NaN));输出查看,结果为number

2.两个传参的例子



	
		
		
		
	
	
		

以上代码运行效果如下:

详解JavaScript的形参,实参以及传参_第3张图片

 这是为什么?

上面的盒子,在行内加了点击事件,这相当于调用了fun函数。形参为i,实参为123

当点击上面的盒子,fnn函数被触发。形参i此时接收实参123,所以执行后面的代码,使得第二个盒子变色


 



	
		
		
		
		
	
	
		

 以为代码运行效果如下:

详解JavaScript的形参,实参以及传参_第4张图片

  这又是为什么?

原本两个盒子都是黄色,但是设置了一个自动执行的函数。实参为dd,形参为e,函数自动执行。形参e接收实参dd,进行判断,是否e == 'dd',这个判断就等价于是否'dd'='dd',这是一个等量代换关系。我们知道这是相等的,所以执行后面的代码,使第二个div编程绿色


总结

如果不调用函数,形参和实参都是摆设。实参可以是一个确定的数,可以是字符串,可以是对象,可以是函数。总而言之,实参相当于一个值,形参相当于一个变量,只不过这个变量没有被声明而已。形参和实参的关系一目了然,形参接受实参。

到这儿,我相信我把这个问题说明白了。

创作不易,希望大家不要吝啬,一键三连呐。

 

你可能感兴趣的:(JS,html,开发语言,javascript,前端)