javascript는 가변 길이 매개변수를 지원합니다. 가변 길이 매개변수를 구현하는 두 가지 방법: 1. 인수 객체의 길이는 인수와 값이 모두 존재할 경우 형식 매개변수의 개수가 아닌 실제 매개변수의 개수에 따라 결정됩니다. 동기화되지만 null 사례 중 하나의 경우 이 null 사례에 대한 값이 동기화되지 않습니다. 2. 나머지 매개변수는 중복 매개변수를 허용하고 이를 배열에 넣는 것을 의미합니다. 구문은 "...변수 이름"입니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, JavaScript 버전 1.8.5, Dell G3 컴퓨터.
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>는 배열
이 아닙니다. Array
와 유사하지만 길이 속성과 인덱스 요소를 제외하고 Array
속성이 없습니다. 예를 들어 팝 메소드가 없습니다. 하지만 실제 배열
로 변환할 수 있습니다.
따라서 다음과 같은 코드를 자주 볼 수 있습니다.
function f(a, b, ...theArgs) { // ... }
arguments
Attributes on<ul style="list-style-type: disc;"><li></ul>
- 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) 비엄격 모드의 함수인 경우🎜아니요 🎜 나머지 매개변수, 기본 매개변수 및 소멸된 할당이 포함된 경우
인수
개체의 값 🎜이 매개변수 값을 🎜추적합니다(그 반대의 경우도 마찬가지). 아래 코드를 보세요: 🎜//以前函数 function f(a, b) { var args = Array.prototype.slice.call(arguments, f.length); // … } // 等效于现在 function f(a, b, ...args) { }
🎜 JS 가변 길이 매개변수 구현 1(가변 매개변수): 나머지 매개변수(...) 🎜🎜
🎜나머지 매개변수( 형식) ...변수 이름), 함수의 추가 매개변수를 얻는 데 사용됩니다. 나머지 매개변수와 일치하는 변수는 배열이며, 이는 중복된 매개변수를 배열에 넣습니다. 가변 길이 매개변수를 처리하는 데 매우 적합합니다. 🎜🎜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 (第四值没有与之对应的变量名)🎜🎜🎜theArgs는 "..."로 시작하고 배열이며 해당 값은 [0,theArgs.length)를 전달하는 실제 호출자에서 옵니다(색인 범위: 0 to theArgs.length-1)🎜🎜🎜🎜🎜Note🎜🎜: 🎜rest 매개변수 뒤에는 다른 매개변수가 있을 수 없습니다(즉, 마지막 매개변수만 가능함). 그렇지 않으면 오류가 보고됩니다. 🎜
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参数不会为每个变量给一个单独的名称,参数对象包含所有参数传递给函数
参数对象不是真正的数组,rest参数是真实的数组实例。例如数组sort、map、forEach、pop的方法都可以直接使用
参数对象有他自己额外的特性(例如callee 属性)
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学习教程 、编程视频】
위 내용은 자바스크립트는 가변 길이 매개변수를 지원합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

JSX 구문 사용 : JSX 구문을 사용하여 JSX 구조를 사용하여 HTML 구조를 JavaScript 코드에 포함시키고 컴파일 후 DOM을 작동시킵니다. 구성 요소는 HTML과 결합됩니다. React 구성 요소는 소품을 통해 데이터를 전달하고 HTML 컨텐츠를 동적으로 생성합니다. 데이터 흐름 관리 : React의 데이터 흐름은 일방 통행이며, 부모 구성 요소에서 자식 구성 요소로 전달되어 이름을 인사말로 전달하는 앱 구성 요소와 같이 데이터 흐름을 제어 할 수 있도록합니다. 기본 사용 예 :지도 함수를 사용하여 목록을 렌더링하려면 과일 목록 렌더링과 같은 주요 속성을 추가해야합니다. 고급 사용 예 : Usestate 후크를 사용하여 상태를 관리하고 역학을 구현합니다.

React는 사용자 인터페이스를 구축하는 효율적이고 유연한 방법을 제공하기 때문에 단일 페이지 응용 프로그램 (SPA)을 구축하는 데 선호되는 도구입니다. 1) 구성 요소 개발 : 복잡한 UI를 독립적이고 재사용 가능한 부품으로 분할하여 유지 가능성과 재사용 성을 향상시킵니다. 2) 가상 DOM : 가상 DOM과 실제 DOM의 차이를 비교하여 렌더링 성능을 최적화합니다. 3) 상태 관리 : 데이터 일관성 및 예측 가능성을 보장하기 위해 상태 및 속성을 통한 데이터 흐름을 관리합니다.

React는 Meta가 사용자 인터페이스를 구축하기 위해 개발 한 JavaScript 라이브러리이며 핵심은 구성 요소 개발 및 가상 DOM 기술입니다. 1. 구성 요소 및 상태 관리 : React는 구성 요소 (기능 또는 클래스) 및 후크 (예 : usestate)를 통해 상태를 관리하여 코드 재사용 및 유지 보수를 개선합니다. 2. 가상 DOM 및 성능 최적화 : 가상 DOM을 통해 실제 DOM을 효율적으로 업데이트하여 성능을 향상시킵니다. 3. 수명주기 및 후크 : 후크 (예 : 사용률) 기능 구성 요소가 수명주기를 관리하고 부작용 작업을 수행 할 수 있도록합니다. 4. 사용 예 : 기본 Helloworld 구성 요소에서 고급 글로벌 주 관리 (Usecontext 및

React Ecosystem에는 주정부 관리 라이브러리 (예 : Redux), 라우팅 라이브러리 (예 : Reactrouter), UI 구성 요소 라이브러리 (예 : 재료 -UI), 테스트 도구 (예 : Jest) 및 Webpack과 같은 빌드 도구 (예 : Webpack)가 포함됩니다. 이러한 도구는 개발자가 애플리케이션을 효율적으로 개발하고 유지하고 코드 품질 및 개발 효율성을 향상시킬 수 있도록 함께 작동합니다.

React는 사용자 인터페이스를 구축하기 위해 Facebook에서 개발 한 JavaScript 라이브러리입니다. 1. 구성 요소 및 가상 DOM 기술을 채택하여 UI 개발의 효율성과 성능을 향상시킵니다. 2. RECT의 핵심 개념에는 구성 요소화, 상태 관리 (예 : usestate 및 useeffect) 및 가상 DOM의 작동 원리가 포함됩니다. 3. 실제 응용 분야에서 React는 기본 구성 요소 렌더링에서 고급 비동기 데이터 처리에 이르기까지 지원됩니다. 4. 주요 속성 추가 또는 잘못된 상태 업데이트를 잊어 버린 것과 같은 일반적인 오류는 ReactDevTools 및 Logs를 통해 디버깅 할 수 있습니다. 5. 성능 최적화 및 모범 사례에는 React.Memo, 코드 세분화 및 코드를 읽기 쉽게 유지하고 신뢰성을 유지하는 것이 포함됩니다.

HTML에서 React의 적용은 구성 요소화 및 가상 DOM을 통한 웹 개발의 효율성과 유연성을 향상시킵니다. 1) 반응 구성 요소화 아이디어는 UI를 재사용 가능한 단위로 나누어 관리를 단순화합니다. 2) 가상 DOM 최적화 성능, Diffing 알고리즘을 통해 DOM 작업을 최소화합니다. 3) JSX Syntax는 JavaScript로 HTML을 작성하여 개발 효율성을 향상시킵니다. 4) usestate 후크를 사용하여 상태를 관리하고 동적 콘텐츠 업데이트를 실현하십시오. 5) 최적화 전략에는 불필요한 렌더링을 줄이기 위해 React.Memo 및 Usecallback 사용이 포함됩니다.

React의 주요 기능에는 구성 요소화 사고, 상태 관리 및 가상 DOM이 포함됩니다. 1) 구성 요소화에 대한 아이디어를 통해 UI를 재사용 가능한 부품으로 나누기 위해 코드 가독성과 유지 관리 가능성을 향상시킵니다. 2) 상태 관리는 상태 및 소품을 통해 동적 데이터를 관리하고 변경 UI 업데이트를 트리거합니다. 3) 가상 DOM 최적화 성능, 메모리에서 DOM 복제의 최소 작동을 계산하여 UI를 업데이트하십시오.

React의 장점은 유연성과 효율성이며, 이는 다음과 같이 반영됩니다. 1) 구성 요소 기반 설계는 코드 재사용 성을 향상시킵니다. 2) 가상 DOM 기술은 특히 다량의 데이터 업데이트를 처리 할 때 성능을 최적화합니다. 3) 풍부한 생태계는 많은 타사 라이브러리와 도구를 제공합니다. React가 어떻게 작동하고 사용하는지 이해함으로써 핵심 개념과 모범 사례를 마스터하여 효율적이고 유지 관리 가능한 사용자 인터페이스를 구축 할 수 있습니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

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

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

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