JavaScript 함수가 변수 매개변수를 구현하는 방법에 대한 자세한 설명은 무엇입니까? (요약 공유)
JS는 약한 형식의 언어이므로 param 키워드를 사용하여 형식 매개변수가 C#과 같은 가변 매개변수임을 선언할 수 없습니다. 그렇다면 이 가변 매개변수를 js에서 어떻게 구현하나요? 다음 글에서는 JavaScript 함수 변수 매개변수의 구현 방법에 대해 설명하겠습니다. 모든 분들께 도움이 되기를 바랍니다.
JS 변수 매개변수 구현 1: 인수
인수란 무엇인가요? 가변 매개변수를 구현하는 방법은 무엇입니까?
arguments는 함수에 전달된 인수에 해당하는 배열형 객체입니다.
ES5에서는 인수 객체를 사용하여 변수 매개변수를 구현할 수 있습니다.
인수 객체의 길이는 형식 매개변수의 개수가 아닌 실제 매개변수의 개수에 따라 결정됩니다. 형식 매개변수는 함수 내의 메모리 공간에서 다시 열리지만 인수 객체의 메모리 공간과 겹치지 않는 변수입니다. 인수와 값이 모두 존재하는 경우에는 두 값이 동기화되지만, 그 중 하나에 값이 없으면 이 값이 없는 경우에는 값이 동기화되지 않습니다.
<script> function dynamicArgs() { var info = "今日签到的学生有:"; for (let i = 0; i < arguments.length ; i ++) { if (i > 0) { info += ","; } info += arguments[i]; } console.log(info); } dynamicArgs("张三", "李四"); dynamicArgs("张三", "李四", "王五", "马六"); dynamicArgs(["张三", "李四", "王五", "马六", "jack", "rose"]); </script>
매개변수가 확실하지 않으니 적어두지 마세요.
호출 시 N개의 여러 매개변수를 작성하거나 배열을 직접 전달할 수 있습니다.
실행 효과:
요약:
1 함수 정의에서 볼 수 있듯이 함수에 가변 매개변수 인수를 사용하면 형식적인 매개변수를 작성할 필요가 없습니다
2. 함수를 호출할 때 여러 실제 매개변수가 함수에 직접 전달될 수 있습니다.
인수 객체는 화살표가 아닌 모든 함수에서 사용할 수 있는 지역 변수입니다. 인수 객체를 사용하여 함수 내에서 함수의 매개변수를 참조할 수 있습니다. 이 객체에는 함수에 전달된 각 매개변수가 포함되어 있으며 첫 번째 매개변수는 인덱스 0입니다. 예를 들어 함수에 세 개의 인수가 전달되면 다음과 같이 참조할 수 있습니다.
arguments[0] arguments[1] arguments[2]
매개변수도 설정할 수 있습니다.
arguments[0] = 'value';
인수
arguments
是一个对象,
不是一个 Array
。它类似于Array
,但除了length属性和索引元素之外没有任何Array
属性。例如,它没有 pop 方法。但是它可以被转换为一个真正的Array
:
所以经常能看到这样的代码:
// 由于arguments不是 Array,所以无法使用 Array 的方法,所以通过这种方法转换为数组 var args = [].slice.call(arguments); // 方式一 var args = Array.prototype.slice.call(arguments); // 方式二 // 下面是 es6 提供的语法 let args = Array.from(arguments) // 方式一 let args = [...arguments]; // 方式二
arguments<span style="font-size: 16px;">上的属性</span>
- arguments.callee:指向当前执行的函数(在 严格模式 下,第5版 ECMAScript (ES5) 禁止使用
a<strong>rguments.callee()</strong>
) - argunments.length:指向传递给当前函数的参数数量
- arguments.caller:已移除
arguments与剩余参数、默认参数和解构赋值参数的结合使用
1)在严格模式下,剩余参数、默认参数和解构赋值参数的存在不会改变 arguments
对象的行为,但是在非严格模式下就有所不同了
function func(a) { arguments[0] = 99; // 更新了arguments[0] 同样更新了a console.log(a); } func(10); // 99 // 并且 function func(a) { a = 99; // 更新了a 同样更新了arguments[0] console.log(arguments[0]); } func(10); // 99
2)当非严格模式中的函数没有包含剩余参数、默认参数和解构赋值,那么arguments
对象中的值会跟踪参数的值(反之亦然)。看下面的代码:
function func(a = 55) { arguments[0] = 99; // updating arguments[0] does not also update a console.log(a); } func(10); // 10 // function func(a = 55) { a = 99; // updating a does not also update arguments[0] console.log(arguments[0]); } func(10); // 10 function func(a = 55) { console.log(arguments[0]); } func(); // undefined
JS可变参数的实现二:rest 参数(...)
在ES6标准中引入了 rest 参数(形式为…变量名
는 개체입니다.</code > code>는 <code>배열
이 아닙니다. Array
와 유사하지만 길이 속성과 인덱스 요소를 제외하고 Array
속성이 없습니다. 예를 들어 pop 메소드가 없습니다. 하지만 실제 배열
로 변환할 수 있습니다.
따라서 다음과 같은 코드를 자주 볼 수 있습니다.
function f(a, b, ...theArgs) { // ... }
arguments
Attributes on<ul style="list-style-type: disc;"><li>
- arguments.callee: 현재 실행 중인 함수를 가리킵니다(엄격 모드에서는 ECMAScript 버전 5(
)에서 a<span style="color: rgb(255, 0, 0);">rguments.callee()</span>
)argunments 사용을 금지합니다. length: 현재 함수에 전달된 인수 수를 가리킵니다.
arguments.caller: 제거됨
인수는 나머지 매개변수, 기본 매개변수 및 소멸된 할당 매개변수와 결합됨
1) 엄격 모드에서는 남아 있음 매개변수, 기본 매개변수 및 파괴된 할당 매개변수는
arguments
객체의 동작을 변경하지 않지만 비엄격 모드에서는 다릅니다function f(arg1, ...rest, arg2) { // arg2 after ...rest ?! // error }
로그인 후 복사2) 비엄격 모드의 함수인 경우- 아니요
나머지 매개변수, 기본 매개변수 및 파괴된 할당이 포함된 경우
의 값이 매개변수 값을인수
개체 추적합니다(그 반대의 경우도 마찬가지). 아래 코드를 보세요: - JS 변수 매개변수 구현 2: 나머지 매개변수(...)🎜
//以前函数 function f(a, b) { var args = Array.prototype.slice.call(arguments, f.length); // … } // 等效于现在 function f(a, b, ...args) { }
로그인 후 복사로그인 후 복사
🎜🎜나머지 매개변수는 ES6 표준에서 도입되었습니다(형식으로.. .변수 이름 code>), 함수의 추가 매개변수를 얻는 데 사용됩니다. 나머지 매개변수와 일치하는 변수는 배열이며, 이는 중복된 매개변수를 배열에 넣습니다. 가변 길이 매개변수를 처리하는 데 매우 적합합니다. 🎜🎜Rest는 전달되는 매개변수 개수의 불일치 문제를 해결하기 위한 것입니다. 이는 추가 매개변수를 승인하여 배열에 넣는 것을 의미하며, Rest 매개변수 자체는 배열이므로 배열과 관련된 모든 방법을 사용할 수 있습니다. 🎜🎜🎜 변수 매개변수의 구현 구문: 🎜🎜
🎜🎜🎜theArgs는 "..."로 시작하고 배열이며 해당 값은 [0,theArgs.length)를 전달하는 실제 호출자에서 옵니다(색인 범위: 0 to theArgs.length-1)🎜🎜🎜🎜🎜Note🎜🎜: 🎜rest 매개변수 뒤에는 다른 매개변수가 있을 수 없습니다(즉, 마지막 매개변수만 가능함). 그렇지 않으면 오류가 보고됩니다. 🎜function f(...[a, b, c]) { return a + b + c; } f(1) //NaN 因为只传递一个值,其实需要三个值 f(1, 2, 3) // 6 f(1, 2, 3, 4) // 6 (第四值没有与之对应的变量名)
로그인 후 복사로그인 후 복사🎜🎜🎜🎜🎜 나머지 매개변수와 매개변수(인수) 객체를 구별하세요 🎜🎜🎜🎜🎜rest 매개변수는 각 변수에 별도의 이름을 부여하지 않으며, 매개변수 객체에는 함수에 전달된 모든 매개변수가 포함됩니다 🎜🎜🎜🎜The 매개변수 객체는 실제 배열이 아니며, 나머지 매개변수는 실제 배열 인스턴스입니다. 예를 들어 배열 정렬, 맵, forEach 및 팝 메소드를 직접 사용할 수 있습니다🎜🎜🎜🎜매개변수 객체에는 자체 추가 기능(예: 호출 수신자 속성)이 있습니다🎜function sumAll(...args) { // args 是数组的名称 let sum = 0; for (let arg of args) sum += arg; return sum; } console.log( sumAll(1) ); // 1 console.log( sumAll(1, 2) ); // 3 console.log( sumAll(1, 2, 3) ); // 6
로그인 후 복사로그인 후 복사
Rest参数的引入减少样式代码
//以前函数 function f(a, b) { var args = Array.prototype.slice.call(arguments, f.length); // … } // 等效于现在 function f(a, b, ...args) { }
Rest参数可以被解构(通俗一点,将rest参数的数据解析后一一对应)不要忘记参数用[] 括起来,因为它数组嘛
function f(...[a, b, c]) { return a + b + c; } f(1) //NaN 因为只传递一个值,其实需要三个值 f(1, 2, 3) // 6 f(1, 2, 3, 4) // 6 (第四值没有与之对应的变量名)
示例
1、计算参数和
function sumAll(...args) { // args 是数组的名称 let sum = 0; for (let arg of args) sum += arg; return sum; } console.log( sumAll(1) ); // 1 console.log( sumAll(1, 2) ); // 3 console.log( sumAll(1, 2, 3) ); // 6
2、每个参数乘以2
function multiply(multiplier, ...theArgs) { return theArgs.map(function(element) { return multiplier * element; }); } var arr = multiply(2, 1, 2, 3); console.log(arr); // [2, 4, 6]
3、排序
function sortRestArgs(...theArgs) { var sortedArgs = theArgs.sort(); return sortedArgs; } //好像一位和两位混合不能进行排序,这需要看一下为甚?主要第一个为主 console.log(sortRestArgs(5, 3, 7, 1)); // shows 1, 3, 5, 7
对比:参数对象arguments不能排序
function sortArguments() { //arguments是参数对象不能直接使用sort()方法,因为不是数组实例,需要转换 var sortedArgs = arguments.sort(); return sortedArgs; // this will never happen } // 会抛出类型异常,arguments.sort不是函数 console.log(sortArguments(5, 3, 7, 1));
【相关推荐:javascript学习教程 、编程视频】
위 내용은 JavaScript 함수가 변수 매개변수를 구현하는 방법에 대한 자세한 설명은 무엇입니까? (요약 공유)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









Go 언어는 클로저와 리플렉션이라는 두 가지 동적 함수 생성 기술을 제공합니다. 클로저는 클로저 범위 내의 변수에 대한 액세스를 허용하며 리플렉션은 FuncOf 함수를 사용하여 새 함수를 생성할 수 있습니다. 이러한 기술은 HTTP 라우터를 사용자 정의하고 고도로 사용자 정의 가능한 시스템을 구현하며 플러그 가능한 구성 요소를 구축하는 데 유용합니다.

C++ 함수 이름 지정에서는 가독성을 높이고 오류를 줄이며 리팩토링을 용이하게 하기 위해 매개변수 순서를 고려하는 것이 중요합니다. 일반적인 매개변수 순서 규칙에는 작업-객체, 개체-작업, 의미론적 의미 및 표준 라이브러리 준수가 포함됩니다. 최적의 순서는 함수의 목적, 매개변수 유형, 잠재적인 혼동 및 언어 규칙에 따라 달라집니다.

효율적이고 유지 관리 가능한 Java 함수를 작성하는 핵심은 단순함을 유지하는 것입니다. 의미 있는 이름을 사용하세요. 특별한 상황을 처리합니다. 적절한 가시성을 사용하십시오.

C++ 함수에서 기본 매개변수의 장점에는 호출 단순화, 가독성 향상, 오류 방지 등이 있습니다. 단점은 제한된 유연성과 명명 제한입니다. 가변 매개변수의 장점에는 무제한의 유연성과 동적 바인딩이 포함됩니다. 단점은 더 큰 복잡성, 암시적 유형 변환 및 디버깅의 어려움을 포함합니다.

1. SUM 함수는 열이나 셀 그룹의 숫자를 합하는 데 사용됩니다(예: =SUM(A1:J10)). 2. AVERAGE 함수는 열이나 셀 그룹에 있는 숫자의 평균을 계산하는 데 사용됩니다(예: =AVERAGE(A1:A10)). 3. COUNT 함수, 열이나 셀 그룹의 숫자나 텍스트 수를 세는 데 사용됩니다. 예: =COUNT(A1:A10) 4. IF 함수, 지정된 조건을 기반으로 논리적 판단을 내리고 결과를 반환하는 데 사용됩니다. 해당 결과.

사용자 정의 PHP 함수와 사전 정의된 함수의 차이점은 다음과 같습니다. 범위: 사용자 정의 함수는 정의 범위로 제한되는 반면, 사전 정의된 함수는 스크립트 전체에서 액세스할 수 있습니다. 정의 방법: 사용자 정의 함수는 function 키워드를 사용하여 정의되는 반면, 사전 정의된 함수는 PHP 커널에 의해 정의됩니다. 매개변수 전달: 사용자 정의 함수는 매개변수를 수신하지만 사전 정의된 함수에는 매개변수가 필요하지 않을 수 있습니다. 확장성: 필요에 따라 사용자 정의 함수를 생성할 수 있으며 사전 정의된 함수는 내장되어 있어 수정할 수 없습니다.

C++의 예외 처리는 특정 오류 메시지, 상황별 정보를 제공하고 오류 유형에 따라 사용자 지정 작업을 수행하는 사용자 지정 예외 클래스를 통해 향상될 수 있습니다. 특정 오류 정보를 제공하려면 std::Exception에서 상속된 예외 클래스를 정의하세요. 사용자 정의 예외를 발생시키려면 throw 키워드를 사용하십시오. try-catch 블록에서 Dynamic_cast를 사용하여 발견된 예외를 사용자 지정 예외 유형으로 변환합니다. 실제 경우 open_file 함수는 FileNotFoundException 예외를 발생시킵니다. 예외를 포착하고 처리하면 보다 구체적인 오류 메시지가 제공될 수 있습니다.

Go에서는 가변 매개변수를 일반 함수에 사용할 수 있으므로 가변 개수의 매개변수를 허용하고 여러 유형에 적합한 일반 함수를 생성할 수 있습니다. 예를 들어, 주어진 목록에서 가장 자주 발생하는 요소를 찾는 일반 함수 Mode를 만들 수 있습니다. Mode는 T 유형의 다양한 요소 수를 허용합니다. 각 요소에 대한 개수를 생성하여 요소의 개수를 계산합니다. 그런 다음 가장 많이 나타나는 요소를 찾아서 모드로 반환합니다. 기본 함수에서 문자열 목록과 정수 목록에 대해 Mode 함수를 호출할 수 있습니다. 이 함수는 각각 가장 많이 나타나는 문자열과 숫자를 반환합니다.
