JavaScript_기본 지식의 세미콜론 삽입 메커니즘에 대한 자세한 소개
은 } 앞, 하나 이상의 줄 바꿈 뒤, 프로그램 입력 끝에만
삽입됩니다.즉, 줄 끝, 코드 블록, 프로그램 끝에서만 세미콜론을 생략할 수 있다는 의미입니다.
즉, 다음 코드를 작성할 수 있습니다
함수 square(x) {
var n = x
n * n 반환
}
하지만 다음과 같은 코드는 작성할 수 없습니다. 그렇지 않으면 오류가 보고됩니다
함수 영역(r) { r = r return Math.PI*r*r }//error
후속 입력 태그를 구문 분석할 수 없는 경우에만
삽입즉, 세미콜론 삽입은 오류 수정 메커니즘입니다. 코드를 보고 이야기해보세요
a = b
(f())
//단가는 다음 문장으로 정확하게 구문 분석할 수 있습니다
a = b(f())
a=b
에프()
//두 개의 독립적인 문으로 구문 분석됨
a = bf();//분석 오류
그래서 법적으로 세미콜론을 생략할 수 있는지 판단하려면 다음 문장의 시작 부분에 주의를 기울여야 합니다.
(, [, , - 및 / 이 5개의 문자가 문을 시작하므로 앞에 세미콜론을 생략하지 않는 것이 가장 좋습니다.
예를 들어주세요
a = b
['r', 'g', 'b'].forEach(함수(키) {
console.log(키);
});
원래는 오류가 없다고 생각하셨는데, 파서가 이를 다음 문장으로 파싱했습니다
a = b['r', 'g', 'b'].forEach(함수 (키) {
console.log(키);
});
두 번째 문이 [로 시작하기 때문에 파서가 첫 번째 문 뒤에 자동으로 세미콜론을 삽입하지 않으므로 위와 같이 파싱됩니다. 위 수식은 b['b'].forEach 로 파싱됩니다.
그래서 이 5개의 문자(, [, , -, / )로 시작하는 문장의 경우 앞에 세미콜론을 생략하지 않는 것이 가장 좋습니다.
세미콜론을 생략하려는 경우 숙련된 프로그래머는 이 명령문 뒤에 선언문을 추가하여 파서가 이를 올바르게 구문 분석하는지 확인합니다. 아래와 같이
a = b
var x//A 선언문은 a = b가 (f())
와 함께 구문 분석되지 않도록 여기에 특별히 추가되었습니다. (f())
따라서 세미콜론을 생략해야 하는 경우에는 다음 줄의 시작 표시가 5개 문자 이상인지 확인해야 합니다. 이로 인해 파서가 세미콜론 자동 삽입을 비활성화하게 되거나, 5개 문자(, [, , - 및 / 앞에 세미콜론을 붙입니다
세미콜론을 생략하면 스크립트 연결 문제가 발생합니다
//file1.js
(함수 () {
//......
})()
//file2.js
(함수 () {
//......
})()
위 두 파일을 연결하면 다음과 같이 파싱됩니다
(함수 () {
//......
})()(함수 () {
//......
})()
따라서 세미콜론을 생략하려면 현재 파일의 다음 토큰뿐만 아니라 스크립트가 연결된 후 명령문 뒤에 나타날 수 있는 토큰도 주의해야 합니다.
파서 구문 분석 오류를 방지하려면 각 파일 앞에 세미콜론을 추가하여 부주의한 연결로부터 스크립트를 보호할 수 있습니다. 파일의 첫 번째 문이 위에서 언급한 5개의 취약한 문자로 열리는 경우 세미콜론 접두사를 추가해야 합니다.
JavaScript 구문으로 인해 제작이 제한됩니다
JavaScript 구문은 제작을 제한합니다. 두 문자 사이에는 줄 바꿈이 허용되지 않습니다.
예:
복귀
{};
위 코드는
로 파싱됩니다.
반품;
{}
;
자동 증가 및 자동 감소 연산을 위한 세미콜론 삽입 규칙
ㅇ
ㄴ
생각해 보세요. 위의 코드는 무엇으로 해석될까요? 증가 연산자는 접두사 연산자와 후위 연산자로 모두 사용될 수 있지만 후위 연산자는 개행 앞에 나타날 수 없으므로 위 코드는
로 구문 분석됩니다.
ㅋㅋㅋ
ㄴ;
빈 for 루프 문 앞에 구분 기호로 세미콜론이 자동으로 삽입되지 않습니다
for (var i = 0,total=1
나는 <길이
나 ) {
합계*=i;
}
위와 같은 코드는 구문 분석 오류를 발생시킵니다.
빈 루프 본문의 while에도 세미콜론을 표시해야 합니다. 그렇지 않으면 구문 분석 오류가 발생합니다
함수 mytest() {
동안(참)
}
오류를 방지하려면 다음과 같이 작성해야 합니다
함수 mytest() {
동안 (사실) ;
}
요약하자면
1. 세미콜론은 } 표시 앞, 줄 끝, 프로그램 끝에서만 추론됩니다.
2. 세미콜론
은 다음 태그를 파싱할 수 없는 경우에만 추론됩니다.
3. (, [, , -, / 문자로 시작하는 문 앞에 세미콜론
을 생략하면 안 됩니다.
4. 스크립트 연결 시 스크립트 사이에 세미콜론
을 명시적으로 삽입하세요.
5. return, throw, break, continue 또는 --
매개변수 앞에는 줄을 끊지 마세요.
6. 세미콜론은 for 루프의 선두나 빈 문의 구분자로 추론할 수 없습니다.

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.

JavaScript는 웹 개발에 널리 사용되는 프로그래밍 언어인 반면 WebSocket은 실시간 통신에 사용되는 네트워크 프로토콜입니다. 두 가지의 강력한 기능을 결합하면 효율적인 실시간 영상 처리 시스템을 만들 수 있습니다. 이 기사에서는 JavaScript와 WebSocket을 사용하여 이 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 첫째, 실시간 영상처리 시스템의 요구사항과 목표를 명확히 할 필요가 있다. 실시간 이미지 데이터를 수집할 수 있는 카메라 장치가 있다고 가정해 보겠습니다.
