아웃트로

길게 읽으셨겠지만 재미있게 읽으셨다고 믿습니다. 어쨌든 궁금한 점이 있거나 제안할 사항이 있으면 언제든지 연락해 주세요.

읽어주셔서 감사합니다. 안녕히 계세요?

","image":"http://www.luping.net/uploads/20240822/172428984466c6933405c14.gif","datePublished":"2024-08-22T09:24:04+08:00","dateModified":"2024-08-22T09:24:04+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 시간 초과를 설정할 필요가 없습니다.

시간 초과를 설정할 필요가 없습니다.

2024-08-22에 게시됨
검색:344

타이머는 오랫동안 많은 사람들이 일상 업무에 사용하는 기능이었습니다. JavaScript 세계에서는 타이머가 setTimeout 또는 setInterval 함수로 구현되는 경우가 많습니다. 그렇게 하는 경우 나쁜 소식은 좋은 습관이 아니라는 점입니다. 그 이유를 설명하겠습니다.

내 생각을 설명하기 전에 질문이 있습니다. 시간을 잘못 알려주는 시계를 사용할 수 있나요?

당신의 대답이 '예'라면, 이 글은 당신의 것이 아니기 때문에 귀중한 시간을 낭비하게 되어 안타깝습니다.

반면, 귀하의 답변이 부정적이라면, setTimeout 또는 setInterval을 사용하는 것이 시간을 확인하기 위해 손상된 시계를 사용하는 것과 왜 같은지 설명하겠습니다.

이 기능의 문제점

시작하려면 다음 스니펫을 살펴보겠습니다.

 function test() {
   let i = 0;
   setTimeout(() => console.log("hello"), 0);
   while (i 


브라우저 콘솔에서 이 스니펫을 실행하면 다음과 같은 결과가 표시됩니다.

You don

이 동작은 setTimeout이 브라우저 대기열에 콜백을 추가하여 유휴 상태일 때 콜백을 처리해야 하기 때문입니다.(할 작업이 없음) 즉, 콜백 setTimeout에 전달된 우선순위가 낮습니다

이제 이것을 알면 setTimeout 함수를 사용하여 타이머를 구현하는 것이 어려울 것이라고 생각합니다. 왜냐하면 동시에 2개 또는 심지어 10개의 틱(브라우저 사용량에 따라 다름)을 가질 수 있기 때문입니다. 디버깅하기에는 악몽이겠지만 더 나은 해결책이 있을까요?

이러한 기능을 피하는 방법

타이머를 구현하는 더 나은 방법을 제공하려면 requestAnimationFrame 함수를 사용해야 합니다. 이는 다음 페인트 이전에 콜백을 실행하도록 브라우저에 지시하기 때문입니다.(즉, UI 변경이 발생하기 전)

여기서의 차이점은 매우 미묘하므로 코드를 통해 이해하는 것이 좋습니다. 이전 코드 조각을 다시 가져와서 setTimeout과 requestAnimationFrame을 비교하기 위해 약간 조정해 보겠습니다.

function testWithAnimationFrame() {
  let i = 0;
  setTimeout(() => console.log("hello"), 0);
  requestAnimationFrame(() => console.log("tell me the next paint"));
  while (i 


이 예에서는 Chrome에서 실행할 때 setTimeout이 requestAnimationFrame 전에 실행되는 것을 볼 수 있습니다. (드물게 그 반대의 경우도 발생하지만)

You don

하지만 Firefox에서 실행하면 다음과 같은 결과가 나옵니다.

You don

혼란스러워 보일 수 있지만 조금만 주의를 기울이면 실행 중에 페인팅이 발생하지 않는다는 것을 알 수 있으므로 이 시나리오를 처리하는 방법은 브라우저에 따라 다릅니다.

이제 브라우저가 페이지를 다시 그리도록 코드 조각을 조정할 수 있다면 어떤 일이 일어나는지 살펴보겠습니다.

function testWithAnimationFrame2() {
  let i = 0;
  setTimeout(() => console.log("hello"), 0);
  requestAnimationFrame(() => console.log("tell me the next paint"));
  while (i 


Chrome의 출력은 다음과 같습니다.

You don

다음은 Firefox의 출력입니다.

You don

로그에서 볼 수 있듯이 브라우저가 UI를 변경할 때 requestAnimationFrame 함수는 항상 예약된 다른 콜백보다 우선순위를 갖습니다.

웹에서는 지속적으로 다시 그리기를 수행하므로 requestAnimationFrame은 타이머를 구현하기 위한 확실한 선택입니다.

requestAnimationFrame 함수 이해

이 함수는 콜백만 매개변수로 사용합니다. 콜백에 컨텍스트를 제공하려면 페이지의 초기 렌더링 시간을 기준으로 이전 프레임이 종료된 시간을 나타내는 타임스탬프를 가져와야 합니다.

이 함수는 요청의 식별자를 나타내는 정수를 반환합니다. 이는 cancelAnimationFrame 함수를 사용하여 요청을 취소하려는 경우 유용할 수 있습니다.

JavaScript로 스톱워치를 간단하게 구현

스톱워치를 구현하려면 몇 가지 요구 사항이 있습니다.

  • 우리는 어느 시간 후에 틱이 표시되어야 하는지 알아야 합니다(일반적으로 1초).
  • 스톱워치가 똑딱거리는 것을 멈춰야 하는 시간의 지연을 알아야 합니다.
  • 틱 간격은 지연보다 작아야 합니다.

이러한 모든 요구 사항을 고려하여 다음 코드 조각은 스톱워치를 생성합니다.

아웃트로

길게 읽으셨겠지만 재미있게 읽으셨다고 믿습니다. 어쨌든 궁금한 점이 있거나 제안할 사항이 있으면 언제든지 연락해 주세요.

읽어주셔서 감사합니다. 안녕히 계세요?

릴리스 선언문 이 기사는 https://dev.to/jospinevans/you-dont-need-to-set-the-time-out-5bfo?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다. 그것
최신 튜토리얼 더>
  • 버퍼: Node.js
    버퍼: Node.js
    Node.js의 버퍼에 대한 간단한 가이드 Node.js의 버퍼는 원시 바이너리 데이터를 처리하는 데 사용되며, 이는 스트림, 파일 또는 네트워크 데이터로 작업할 때 유용합니다. 버퍼를 만드는 방법 문자열에서: const buf = ...
    프로그램 작성 2024-11-05에 게시됨
  • Node.js의 버전 관리 마스터하기
    Node.js의 버전 관리 마스터하기
    개발자로서 우리는 다양한 Node.js 버전을 요구하는 프로젝트를 자주 접하게 됩니다. 이 시나리오는 Node.js 프로젝트에 정기적으로 참여하지 않는 신규 개발자와 숙련된 개발자 모두에게 함정입니다. 즉, 각 프로젝트에 올바른 Node.js 버전이 사용되는지 확인하는...
    프로그램 작성 2024-11-05에 게시됨
  • 문제 해결을 위해 Go 바이너리에 Git 개정 정보를 포함하는 방법은 무엇입니까?
    문제 해결을 위해 Go 바이너리에 Git 개정 정보를 포함하는 방법은 무엇입니까?
    Go 바이너리에서 Git 개정 확인코드를 배포할 때 바이너리를 빌드된 Git 개정과 연결하는 것이 도움이 될 수 있습니다. 문제 해결 목적. 그러나 개정 번호로 소스 코드를 직접 업데이트하는 것은 소스를 변경하므로 불가능합니다.해결책: 빌드 플래그 활용이 문제에 대한 ...
    프로그램 작성 2024-11-05에 게시됨
  • 일반적인 HTML 태그: 관점
    일반적인 HTML 태그: 관점
    HTML(HyperText Markup Language)은 웹 개발의 기초를 형성하며 인터넷의 모든 웹페이지 구조 역할을 합니다. 2024년 가장 일반적인 HTML 태그와 고급 용도를 이해함으로써 개발자는 보다 효율적이고 접근 가능하며 시각적으로 매력적인 웹 페이지를 ...
    프로그램 작성 2024-11-05에 게시됨
  • CSS 미디어 쿼리
    CSS 미디어 쿼리
    웹사이트가 다양한 기기에서 원활하게 작동하도록 보장하는 것이 그 어느 때보다 중요합니다. 사용자가 데스크톱, 노트북, 태블릿, 스마트폰에서 웹사이트에 액세스함에 따라 반응형 디자인이 필수가 되었습니다. 반응형 디자인의 중심에는 개발자가 사용자 기기의 특성에 따라 다양한...
    프로그램 작성 2024-11-05에 게시됨
  • JavaScript의 호이스팅 이해: 종합 가이드
    JavaScript의 호이스팅 이해: 종합 가이드
    자바스크립트에서 호이스팅 호이스팅은 변수 및 함수 선언을 포함 범위(전역 범위 또는 함수 범위)의 맨 위로 이동(또는 "호이스팅")하는 동작입니다. 코드가 실행됩니다. 즉, 코드에서 실제로 선언되기 전에 변수와 함수를 사용할 수 있습니...
    프로그램 작성 2024-11-05에 게시됨
  • Stripe를 단일 제품 Django Python Shop에 통합
    Stripe를 단일 제품 Django Python Shop에 통합
    In the first part of this series, we created a Django online shop with htmx. In this second part, we'll handle orders using Stripe. What We'll...
    프로그램 작성 2024-11-05에 게시됨
  • Laravel에서 대기 중인 작업을 테스트하기 위한 팁
    Laravel에서 대기 중인 작업을 테스트하기 위한 팁
    Laravel 애플리케이션으로 작업할 때 명령이 비용이 많이 드는 작업을 수행해야 하는 시나리오를 접하는 것이 일반적입니다. 기본 프로세스를 차단하지 않으려면 대기열에서 처리할 수 있는 작업으로 작업을 오프로드하기로 결정할 수 있습니다. 예제를 살펴보겠습니다. app:...
    프로그램 작성 2024-11-05에 게시됨
  • 인간 수준의 자연어 이해(NLU) 시스템을 만드는 방법
    인간 수준의 자연어 이해(NLU) 시스템을 만드는 방법
    Scope: Creating an NLU system that fully understands and processes human languages in a wide range of contexts, from conversations to literature. ...
    프로그램 작성 2024-11-05에 게시됨
  • JSTL을 사용하여 HashMap 내에서 ArrayList를 반복하는 방법은 무엇입니까?
    JSTL을 사용하여 HashMap 내에서 ArrayList를 반복하는 방법은 무엇입니까?
    JSTL을 사용하여 HashMap 내에서 ArrayList 반복웹 개발에서 JSTL(JavaServer Pages Standard Tag Library)은 JSP( 자바 서버 페이지). 그러한 작업 중 하나는 데이터 구조를 반복하는 것입니다.HashMap과 그 안에 포...
    프로그램 작성 2024-11-05에 게시됨
  • Encore.ts — ElysiaJS 및 Hono보다 빠릅니다.
    Encore.ts — ElysiaJS 및 Hono보다 빠릅니다.
    몇 달 전 우리는 TypeScript용 오픈 소스 백엔드 프레임워크인 Encore.ts를 출시했습니다. 이미 많은 프레임워크가 있으므로 우리는 우리가 내린 흔하지 않은 디자인 결정과 그것이 어떻게 놀라운 성능 수치로 이어지는지 공유하고 싶었습니다. 성능 ...
    프로그램 작성 2024-11-05에 게시됨
  • 문자열 리터럴에서 +를 사용한 문자열 연결이 실패하는 이유는 무엇입니까?
    문자열 리터럴에서 +를 사용한 문자열 연결이 실패하는 이유는 무엇입니까?
    문자열 리터럴을 문자열과 연결C에서는 연산자를 사용하여 문자열과 문자열 리터럴을 연결할 수 있습니다. 그러나 이 기능에는 혼란을 초래할 수 있는 제한 사항이 있습니다.질문에서 작성자는 문자열 리터럴 "Hello", ",world" 및...
    프로그램 작성 2024-11-05에 게시됨
  • React Re-Rendering: 최적의 성능을 위한 모범 사례
    React Re-Rendering: 최적의 성능을 위한 모범 사례
    React의 효율적인 렌더링 메커니즘은 React가 인기를 얻는 주요 이유 중 하나입니다. 그러나 애플리케이션이 복잡해짐에 따라 구성 요소 다시 렌더링을 관리하는 것이 성능을 최적화하는 데 중요해졌습니다. React의 렌더링 동작을 최적화하고 불필요한 재렌더링을 방지하...
    프로그램 작성 2024-11-05에 게시됨
  • 조건부 열 생성을 달성하는 방법: Pandas DataFrame에서 If-Elif-Else 탐색?
    조건부 열 생성을 달성하는 방법: Pandas DataFrame에서 If-Elif-Else 탐색?
    조건부 열 생성: Pandas의 If-Elif-Else주어진 문제에서는 DataFrame에 새 열을 추가해야 합니다. 일련의 조건부 기준을 기반으로 합니다. 문제는 코드 효율성과 가독성을 유지하면서 이러한 조건을 구현하는 것입니다.함수 적용을 사용한 솔루션한 가지 접근...
    프로그램 작성 2024-11-05에 게시됨
  • 큐를 소개합니다!
    큐를 소개합니다!
    원시 SQL을 다시 재미있게 만들기 위해 설계된 실용적인 SQL 쿼리 실행기인 Qiu의 출시를 발표하게 되어 기쁩니다. 솔직하게 말하면 ORM이 그 자리를 차지하지만 간단한 SQL을 작성하는 것만으로도 약간 부담스러울 수 있습니다. 저는 항상 원시 SQL 쿼리를 작성하...
    프로그램 작성 2024-11-05에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3