> 웹 프론트엔드 > JS 튜토리얼 > JavaScript의 자동 세미콜론 삽입(ASI)은 어떻게 작동하며 그 위험을 어떻게 피할 수 있습니까?

JavaScript의 자동 세미콜론 삽입(ASI)은 어떻게 작동하며 그 위험을 어떻게 피할 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-24 05:42:15
원래의
784명이 탐색했습니다.

How Does JavaScript's Automatic Semicolon Insertion (ASI) Work and How Can I Avoid Its Pitfalls?

JavaScript의 ASI(자동 세미콜론 삽입) 규칙

JavaScript의 ASI는 특정 문의 끝에 세미콜론이 누락된 경우 자동으로 삽입할 수 있는 기능입니다. 이는 경우에 따라 유용할 수 있지만 버그가 발생할 수도 있습니다.

ASI의 영향을 받는 문

ASI는 다음 유형의 문에 적용됩니다.

  • 빈문
  • Var문
  • 표현식 문
  • Do-while 문
  • Continue 문
  • Break 문
  • Return 문
  • Throw 문

ASI 규칙

특정 규칙 ASI는 다음과 같습니다.

  1. 문법에서 허용되지 않는 잘못된 토큰이 발견되면 다음과 같은 경우 세미콜론이 그 앞에 삽입됩니다.

    • 토큰 이전 토큰과 최소한 한 줄 바꿈으로 구분됩니다.
    • 토큰은 닫는 중괄호입니다. (}).
  2. 토큰 입력 스트림의 끝에 도달하고 파서가 입력 토큰 스트림을 단일 완전한 프로그램으로 구문 분석할 수 없는 경우 끝에 세미콜론이 자동으로 삽입됩니다.
  3. 문법에 따라 토큰이 허용되지만 생산이 제한된 생산인 경우 제한된 생산 앞에 세미콜론이 자동으로 삽입됩니다. token.

제한된 제작에는 다음이 포함됩니다.

  • 업데이트 표현식( , --)
  • Continue 문
  • Break 문
  • 반품문
  • 던지기 명령문
  • 화살표 함수
  • 수익률 표현식

예 1:

ASI가 이 코드를 변환할 것입니다. to:

예 2:

ASI는 이 코드를 다음으로 변환합니다:

예 3:

ASI는 이 코드를 다음과 같이 변환합니다.

ASI 버그 방지

ASI는 유용한 기능일 수도 있지만, 버그로 이어집니다. ASI 버그를 방지하려면 항상 각 명령문 끝에 세미콜론을 명시적으로 사용하는 것이 가장 좋습니다.

위 내용은 JavaScript의 자동 세미콜론 삽입(ASI)은 어떻게 작동하며 그 위험을 어떻게 피할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿