웹 프론트엔드 JS 튜토리얼 SetTimeout에는 실제로 세 번째 매개변수가 있습니까?

SetTimeout에는 실제로 세 번째 매개변수가 있습니까?

Dec 09, 2019 pm 05:47 PM
settimeout 매개변수

SetTimeout에는 실제로 세 번째 매개변수가 있습니까?

setTimeout에 실제로 세 번째 매개변수가 있나요?

setTimeout에 대해 말하자면, 모두가 익숙하고 사용법도 매우 간단합니다: setTimeout(fun, Delay).

하지만 믿기지 않으실 수도 있겠지만, 오랫동안 사용되어 온 setTimeout에는 실제로 세 번째 매개변수가 있습니다. setTimeout의 세 번째 매개변수를 살펴보겠습니다.

[관련 강좌 추천 : JavaScript 영상 튜토리얼]

먼저 간단한 코드를 살펴보겠습니다.

setTimeout(function(x) {
    console.log(x);
}, 1000, 1);
로그인 후 복사

콘솔 출력이 1인데 계속해서 매개변수를 추가해도 될까요? 다음 코드를 계속 살펴보겠습니다.

setTimeout(function(x,y) {
    console.log(x+y);
}, 1000, 1, 2);
로그인 후 복사

콘솔 출력은 3입니다. 이는 분명히 세 번째와 네 번째 매개변수의 합입니다.

이것을 보고 많은 친구들은 setTimeout의 세 번째 매개변수가 setTimeout의 첫 번째 함수의 매개변수라는 것을 깨닫게 될 것입니다.

MDN https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout을 쿼리하면 세 번째 매개변수에 대한 설명을 볼 수 있습니다.

var timeoutID = scope.setTimeout(function[, delay, arg1, arg2, ...]);
var timeoutID = scope.setTimeout(function[, delay]);
var timeoutID = scope.setTimeout(code[, delay]);
로그인 후 복사

따라서 정확하게 말하면 setTimeout은 다음을 가질 수 있습니다. 수많은 매개변수가 있지만 세 번째 매개변수부터는 선택 매개변수입니다.

이 기능을 알고 나면 어떤 문제를 해결할 수 있을까요? 가장 고전적인 방법은 for 루프 내에서 setTimeout을 사용하는 것입니다.

for(var i = 0; i<6; i++) {
    setTimeout(function() {
        console.log(i);
    }, 1000);
}
로그인 후 복사

위의 예는 전형적인 인터뷰 질문입니다. setTimeout은 비동기 작업이고 setTimeout이 실행될 때 for 루프가 실행되었으며 이때 i는 이미 다음과 같습니다. 6이므로 6 곱하기 6이 출력됩니다. 나는 몇 가지 해결책을 요약했습니다. 관심 있는 친구들은 나의 마지막 블로그인 "for loops에서 setTimeout 사용에 대하여"를 읽을 수 있습니다. 이 블로그의 마지막 부분에서 setTimeout의 세 번째 매개변수 사용에 대해 언급했습니다.

for(var i=0;i<6;i++) {
    setTimeout(function(j) {
        console.log(j);
    }, 1000, i);
}
로그인 후 복사

전달된 각 매개변수는 for 루프에서 가져온 값이므로 0~5가 순차적으로 출력됩니다. 물론 이것은 여전히 ​​범위 문제이지만 여기서는 setTimeout의 세 번째 매개변수가 i 값을 저장합니다. 이 솔루션은 클로저를 사용하는 것보다 훨씬 가볍습니다.

또한 세 번째 매개변수도 함수로 사용할 수 있습니다.

for(var i=0;i<6;i++) {

    setTimeout(function(j) {

        console.log(j);

    }, 1000, i);

}
로그인 후 복사

최종 출력은 처음에는 0, 두 번째에는 1입니다.

세 번째 매개변수도 먼저 실행한 후 함수가 실행되는 것을 볼 수 있습니다.

마지막으로 세 번째 매개변수를 사용할 때 주의해야 할 점은 호환성 문제입니다. IE9 및 이전 버전과 호환되어야 한다면 MDN에서 제공하는 호환되는 이전 IE 코드를 도입해야 합니다 https ://developer.mozilla.org/zh-CN /docs/Web/API/Window/setTimeout#%E5%85%BC%E5%AE%B9%E6%97%A7%E7%8E%AF%E5% A2%83%EF%BC%88polyfill%EF% BC%89, 포털은 여기에 게시되어 있으니 관심이 있으시면 확인하실 수 있습니다.

다음은 MDN의 호환성에 대한 설명입니다.

Note: Passing additional arguments to the function in the first syntax does not work in Internet Explorer 9 and below. If you want to enable this functionality on that browser, you must use a polyfill (see the Polyfill section).
로그인 후 복사

이 기사는 js tutorial 칼럼에서 가져온 것입니다. 배우신 것을 환영합니다!

위 내용은 SetTimeout에는 실제로 세 번째 매개변수가 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

PHP 버전 5.4의 새로운 기능: 호출 가능 유형 힌트 매개변수를 사용하여 호출 가능 함수 또는 메서드를 허용하는 방법 PHP 버전 5.4의 새로운 기능: 호출 가능 유형 힌트 매개변수를 사용하여 호출 가능 함수 또는 메서드를 허용하는 방법 Jul 29, 2023 pm 09:19 PM

PHP5.4 버전의 새로운 기능: 호출 가능 유형 힌트 매개변수를 사용하여 호출 가능 함수 또는 메소드를 허용하는 방법 소개: PHP5.4 버전에는 매우 편리한 새 기능이 도입되었습니다. 호출 가능 유형 힌트 매개변수를 사용하여 호출 가능 함수 또는 메소드를 허용할 수 있습니다. 이 새로운 기능을 사용하면 함수와 메서드가 추가 확인 및 변환 없이 해당 호출 가능 매개변수를 직접 지정할 수 있습니다. 이 기사에서는 호출 가능 유형 힌트의 사용을 소개하고 몇 가지 코드 예제를 제공합니다.

제품 매개변수는 무엇을 의미합니까? 제품 매개변수는 무엇을 의미합니까? Jul 05, 2023 am 11:13 AM

제품 매개변수는 제품 속성의 의미를 나타냅니다. 예를 들어 의류 매개변수에는 브랜드, 소재, 모델, 크기, 스타일, 직물, 적용 그룹, 색상 등이 포함됩니다. 식품 매개변수에는 브랜드, 중량, 재료, 건강 허가 번호, 적용 그룹, 색상 등이 포함됩니다. 브랜드, 크기, 색상, 원산지, 적용 가능한 전압, 신호, 인터페이스 및 전원 등이 포함됩니다.

PHP 경고: in_array()에 대한 솔루션에는 매개변수가 필요합니다. PHP 경고: in_array()에 대한 솔루션에는 매개변수가 필요합니다. Jun 22, 2023 pm 11:52 PM

개발 과정에서 다음과 같은 오류 메시지가 나타날 수 있습니다: PHPWarning: in_array()expectsparameter. 이 오류 메시지는 in_array() 함수를 사용할 때 나타나는데, 이는 함수의 잘못된 매개변수 전달로 인해 발생할 수 있습니다. 이 오류 메시지에 대한 해결 방법을 살펴보겠습니다. 먼저 in_array() 함수의 역할을 명확히 해야 합니다. 즉, 배열에 값이 존재하는지 확인해야 합니다. 이 함수의 프로토타입은 다음과 같습니다: in_a

i9-12900H 매개변수 평가 목록 i9-12900H 매개변수 평가 목록 Feb 23, 2024 am 09:25 AM

i9-12900H는 14코어 프로세서로, 사용된 아키텍처와 기술이 모두 새롭고, 전반적인 작업이 매우 뛰어나며, 특히 포괄적이며 사용자에게 뛰어난 경험을 제공할 수 있습니다. . i9-12900H 매개변수 평가 검토: 1. i9-12900H는 14코어 프로세서로, q1 아키텍처와 24576kb 프로세스 기술을 채택하고 20스레드로 업그레이드되었습니다. 2. 최대 CPU 주파수는 1.80!5.00ghz이며 주로 작업량에 따라 다릅니다. 3. 가격에 비해 가격 대비 성능이 매우 적합하며 정상적인 사용이 필요한 일부 파트너에게 매우 적합합니다. i9-12900H 매개변수 평가 및 성능 벤치마크

C++ 함수 매개변수 유형 안전성 확인 C++ 함수 매개변수 유형 안전성 확인 Apr 19, 2024 pm 12:00 PM

C++ 매개변수 유형 안전성 검사는 함수가 컴파일 시간 검사, 런타임 검사 및 정적 어설션을 통해 예상된 유형의 값만 허용하도록 보장하여 예기치 않은 동작 및 프로그램 충돌을 방지합니다. 컴파일 시간 유형 검사: 컴파일러가 유형 호환성을 검사합니다. 런타임 유형 검사: 동적_캐스트를 사용하여 유형 호환성을 확인하고 일치하는 항목이 없으면 예외를 발생시킵니다. 정적 어설션: 컴파일 타임에 유형 조건을 어설션합니다.

주어진 값을 인수로 취하는 역쌍곡사인 함수의 값을 찾는 C++ 프로그램 주어진 값을 인수로 취하는 역쌍곡사인 함수의 값을 찾는 C++ 프로그램 Sep 17, 2023 am 10:49 AM

쌍곡선 함수는 원 대신 쌍곡선을 사용하여 정의되며 일반 삼각 함수와 동일합니다. 제공된 각도(라디안)에서 쌍곡사인 함수의 비율 매개변수를 반환합니다. 그러나 반대로 하십시오. 즉, 반대로 하십시오. 쌍곡선 사인으로부터 각도를 계산하려면 쌍곡선 역사인 연산과 같은 역쌍곡선 삼각법 연산이 필요합니다. 이 과정에서는 라디안 단위의 쌍곡선 사인 값을 사용하여 각도를 계산하기 위해 C++에서 쌍곡선 역사인(asinh) 함수를 사용하는 방법을 보여줍니다. 쌍곡선 아크사인 연산은 다음 공식 -$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})}을 따릅니다. 여기서\:In\:은\:자연 로그\:(log_e\:k)

100억 개의 매개변수가 있는 언어 모델을 실행할 수 없나요? MIT의 한 중국 의사는 SmoothQuant 정량화를 제안했는데, 이는 메모리 요구 사항을 절반으로 줄이고 속도를 1.56배 높였습니다! 100억 개의 매개변수가 있는 언어 모델을 실행할 수 없나요? MIT의 한 중국 의사는 SmoothQuant 정량화를 제안했는데, 이는 메모리 요구 사항을 절반으로 줄이고 속도를 1.56배 높였습니다! Apr 13, 2023 am 09:31 AM

LLM(Large Language Model)은 강력한 성능을 갖고 있지만 매개변수의 수는 쉽게 수백억, 수천억에 달할 수 있고 컴퓨팅 장비와 메모리에 대한 수요도 일반 기업이 감당할 수 없을 만큼 크다. 양자화는 모델 가중치의 정확도(예: 32비트를 8비트로)를 줄여 추론 속도를 높이고 메모리 요구 사항을 줄이는 대신 일부 모델 성능을 희생하는 일반적인 압축 작업입니다. 그러나 1,000억 개 이상의 매개변수가 있는 LLM의 경우 기존 압축 방법으로는 모델의 정확성을 유지할 수 없으며 하드웨어에서 효율적으로 실행할 수도 없습니다. 최근 MIT와 NVIDIA의 연구원들은 범용 사후 훈련 양자화(GPQ)를 공동으로 제안했습니다.

settimeout과 setinterval의 차이점은 무엇입니까 settimeout과 setinterval의 차이점은 무엇입니까 Aug 15, 2023 pm 02:06 PM

settimeout과 setInterval의 차이점: 1. 트리거 시간, settimeout은 일회성이며 지연 시간을 설정한 후 함수를 한 번 실행하지만 setinterval은 반복적이며 설정된 시간 간격으로 함수를 반복적으로 실행합니다. , settimeout은 한 번만 실행되고 setinterval은 취소될 때까지 반복적으로 실행됩니다.

See all articles