【JavaScript】34_可变参数
【摘要】 19、可变参数 argumentsarguments是函数中又一个隐含参数arguments是一个类数组对象(伪数组)和数组相似,可以通过索引来读取元素,也可以通过for循环变量,但是它不是一个数组对象,不能调用数组的方法arguments用来存储函数的实参,无论用户是否定义形参,实参都会存储到arguments对象中可以通过该对象直接访问实参 <script> fun...
19、可变参数
arguments
-
arguments是函数中又一个隐含参数
-
arguments是一个类数组对象(伪数组)
和数组相似,可以通过索引来读取元素,也可以通过for循环变量,但是它不是一个数组对象,不能调用数组的方法
-
arguments用来存储函数的实参,
无论用户是否定义形参,实参都会存储到arguments对象中
可以通过该对象直接访问实参
<script>
function fn(){
console.log(arguments[2])//读取到下标为2的函数参数
console.log(Array.isArray(arguments))//false
for(let i = 0; i < arguments.length; i++){
console.log(arguments[i])
}
//上下两种循环效果一样
for(let v of arguments){
console.log(v)
}
arguments.forEach(element => {console.log(element)});
}
fn(1,10,23)
//定义一个函数,可以求任意个数值的和
function sum(){
//通过arguments,可以不受参数数量的限制更加灵活的创建函数
let result = 0;
for(let num of arguments){
result += num
}
return result
}
</script>
可变参数,在定义函数时可以将参数指定为可变参数
-
可变参数可以接收任意数量实参,并将他们统一存储到一个数组中返回
-
可变参数的作用和arguments基本是一致,但是也具有一些不同点:
-
可变参数的名字可以自己指定
-
可变参数就是一个数组,可以直接使用数组的方法
-
可变参数可以配合其他参数一起使用
-
<script>
function fn2(...abc){
console.log(abc)
}
function sum2(...num){
return num.reduce((a,b) => a + b, 0)
}
// 当可变参数和普通参数一起使用时,需要将可变参数写到最后
function fn3(a, b, ...args) {
// for (let v of arguments) {
// console.log(v)
// }
console.log(args)
}
fn3(123, 456, "hello", true, "1111")
</script>
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)