js函数的参数:arguments对象的使用、给参数设置默认值、通过对象/值 传递参数、
知识点:
JavaScript 函数对参数的值(arguments)没有进行任何的检查。
JavaScript 函数参数与大多数其他语言的函数参数的区别在于:它不会关注有多少个参数被传递,不关注传递的参数的数据类型。
参数规则:
JavaScript 函数定义时参数没有指定数据类型。
JavaScript 函数对隐藏参数(arguments)没有进行检测。
JavaScript 函数对隐藏参数(arguments)的个数没有进行检测。
==============================================================
arguments对象代表传入参数,组成的一个数组:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>W3Cschool教程(w3cschool.cn)</title> </head> <body> <p>查找最大的数。</p> <p id="demo"></p> <script> //算法:1.如果只有一个参数,直接返回 // 2.有多个参数,则和max默认值一一比对,max小于它的,就把它赋值给max,最后返回max x = findMax(1, 123, 500, 115, 44, 88); function findMax() { var i,max=arguments[0]; if (arguments.length<2)return max; for(i=0;i<arguments.length;i++){ if(max<arguments[i])max=arguments[i]; } return max; } document.getElementById("demo").innerHTML = x; </script> </body> </html>
给函数参数,参数如果不设置,默认值为undefined,建议给参数设置默认值,写法一:
function myFunction(x, y) {
if (y === undefined) {
y = 0;
}
}
给函数参数设置默认值写法二(如果y已经定义 , y || 0返回 y, 因为 y 是 true, 否则返回 0, 因为 undefined 为 false):
function myFunction(x, y) {
y = y || 0;
}
用【arguments对象】来计算所有传入参数的和:
x = sumAll(1, 123, 500, 115, 44, 88); function sumAll() { var i, sum = 0; for (i = 0; i < arguments.length; i++) { sum += arguments[i]; } return sum; }
通过值传递参数
在函数中调用的参数是函数的参数。
如果函数修改参数的值,将不会修改参数的初始值(在函数外定义)。
总结:JavaScript函数传值只是将参数的值传入函数,函数会另外配置内存保存参数值,所以并不会改变原参数的值
var x = 1; // 通过值传递参数 function myFunction(x) { x++; //修改参数x的值,将不会修改在函数外定义的变量 x console.log(x); } myFunction(x); // 2 console.log(x); // 1
通过对象传递参数
在JavaScript中,可以引用对象的值。
因此我们在函数内部修改对象的属性就会修改其初始的值。
修改对象属性可作用于函数外部(全局变量)
var obj = {x:1}; // 通过对象传递参数 function myFunction(obj) { obj.x++; //修改参数对象obj.x的值,函数外定义的obj也将会被修改 console.log(obj.x); } myFunction(obj); // 2 console.log(obj.x); // 2
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现