JS的形参与实参

更新日期: 2020-01-30 阅读: 2.5k 标签: 参数

函数的参数

参数是指由外部传入到函数中的变量,仅作为变量使用,但是该变量可以是任何内容,包括函数。被传入的参数作为私有变量使用,可以被覆盖掉。参数排列是严格按照参数的顺序填入的

JavaScript中函数的参数分为形参实参

形参:是在定义函数时使用的参数,目的是用来接收调用该函数时传进来的实际参数。
实参:是在调用时传递给函数的参数。
function myfun(a,b){                   //形参就是a和b
	return a+b;
}
console.log(myfun(1,2));//输出5        //实参就是1和2

函数的形参没有限制,可以没有或者多个。形参的数量可以通过函数的length属性获取。

function myfun(a,b,c){                  
	return a+b+c;
}
console.log(myfun.length);             //返回3,形参的个数

一般来说,函数的形参和实参个数是相等的,但在JavaScript中没有规定两者必须相等。

函数中实参与形参是依次对应的,严格按照填入的顺序,即第1个实参的值传递给第1个形参,第2个实参的值传递给第2个形参,以此类推

如果实参个数大于形参,那么多出的实参就无法被形参访问,不传递其值而被忽略掉。

如果形参个数大于实参,那么多出的形参值为undefined。

var myfun=function(m,n){  // 2个形参
   document.write("m="+m);
   document.write("n="+n);
}
myfun(1,2);   // 2个实参,实参等于形参
document.write("<br />");
myfun(1,2,3);  // 3个实参,实参大于形参
ocument.write("<br />");
myfun(1);  // 1个实参,实参小于形参

输出结果为:

m=1 n=2
m=1 n=2
m=1 n=undefined

函数也能作为参数传递给另一个函数,也可以作为返回值。有利于进行模块化编程。如下所示

function a(f,x,y){   //定义一个函数a,里面的形参f就是函数
	return f(x,y);		//函数a返回的就是函数f的执行结果
}
function b(x,y){
	return x+y;
}
console.log(a(b,1,2));//输出3,这里的b就是函数b,也就是形参f

如果出现参数的个数不确定 我们可以不定义参数

如果是单纯的值传递: 形参的赋值,不会影响到实参。但是,如果是引用传递,那么变形参的值,相当于改变了引用,会改变实参的值

拓展:JavaScript定义了arguments对象,用于在函数内部执行,arguments.length是可以快速获取函数的实参个数,使用arguments[n]可以获取实参的值。

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/8476

相关推荐

如何给外部引用的js文件传递参数

给外部引用的js文件传递参数的4种方式:定义全局变量、在src后面传参、检索js文件(js文件要最后引入)、设置其他属性

用js获取url地址协议,参数,端口号,锚点等方法总汇

在前端开发中,经常会遇到获取URL的相关数据,下面将总结下使用JavaScript来获取url地址的协议,参数,端口号,锚点等方法。

URLSearchParams_js中快速构造和获取URL查询参数的方法

URLSearchParams 接口定义了一些实用的方法来处理 URL 的查询字符串。URLSearchParams()是个构造函数,将返回一个可以操作查询字符串的对象。

vue中监听路由参数的变化

在vue项目中,假使我们在同一个路由下,只是改变路由后面的参数值,期望达到数据的更新。getDetail()方法中会用到this.id这个参数,在同一页面切换id的值,并不会触发vue的声明周期函数。

Vue页面传参方式Query和Params

query需要和配合 path 属性使用,携带参数会拼接在请求路径后,效果同 Get 请求方式;params需要配合 name 属性使用,参数不会携带在访问路径后

你需要了解的前后端传参

前后端传参一般有两种形式:key=value 形式传参(即 parameter 形式);body 形式传参(传 json 数据给后端),如果使用的是 GET 请求,浏览器展示的 Request URL 会自动在路径后面加上 ?a=1&b=2这样的参数,这就是 key=value 形式传参

vue-router动态路由设置参数可选

在日常工作中,我们需要将匹配到的所有路由,映射到一个组件上。如下代码想要达到的效果:不传page和id,则映射到user默认list页面,传page和id,根据page不同,显示不同的页面

小程序获取当前路径和参数

currentPage is not defined;opyions is not defined;不细心的我少写了前两句,以为参数是可以直接引用的,注意this的使用,有时需要定义全局变量来调用

js通过arguments来获取指定参数

通过访问arguments对象的length属性可以获取有多少个参数传递给了函数。在封装函数的时候,会携带不同的参数,我们想要获取指定的参数,可以通过 arguments[ ] 来拿到,arguments对象可以与命名参数一起使用。arguments的值要永远与对应命名参数的值保持同步

用正则表达式获取URL中的查询参数

url中的所有查询参数可以通过 window.location.search 字段获取,以字符串的形式返回。并有固定的格式 ?param1=value1&param2=value2···,所以可以正则表达式匹配。分析下需要匹配的格式:

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!