Script 탭 과 스 크 립 트 실행 순서
3606 단어 JavaScript
script 태그 와 관련 된 스 크 립 트 실행 순 서 를 자세히 이야기 합 니 다.Script 탭 의 기본 동작
몇 가지 최 우선 특성:
script ( defer async ) 。 。
document.currentScript (Chrome 29+, FF4+)
script
다음 과 같은 간단 한 코드 1 을 가정 하면 최종 적 으로 세 개의 alert 가 'A', 'B', 'C' 순이다.
우 리 는 네트워크 요청 이 있 는 상황 을 다시 고려 합 니 다. 2.
세 파일 모두 먼저 다운로드 하고 실행 해 야 하 며 두 번 째 파일 의 크기 는 다른 두 파일 보다 훨씬 크다.그러나 결 과 는 여전히 세 개의 alert 가 튀 어 나 왔 고 내용 은 'A', 'B', 'C' 였 다.
위의 두 가지 예 에서 script 태그 의 플런저 식 실행 을 충분히 알 수 있 습 니 다.async 속성
async 속성 은 HTML 5 의 새로운 특성 3 으로 호환성 이 좋 지 않다 는 것 을 의미한다 (IE10 +).
async 는 이 script 태그 가 플런저 가 아니 라 동기 화 되 지 않 음 을 표시 합 니 다.브 라 우 저 는 스 크 립 트 다운로드 가 끝 난 후에 실행 하면 됩 니 다. 플런저 페이지 를 렌 더 링 하지 않 고 이 스 크 립 트 의 다운로드 와 실행 을 기다 리 지 않 아 도 됩 니 다.
다음 코드 4 는 세 개의 alert 를 얻 을 수 있 지만 alert 의 내용 은 각각 "A", "C", "B" 입 니 다.
두 번 째 script 태그 가 async 에 가입 하 는 것 을 막 지 않 았 음 을 알 수 있 습 니 다.
이 속성 이 생 긴 원래 의 것 을 고려 하면 대량의 스 크 립 트 로 더 가 이런 일 을 하고 있 습 니 다.
var script = document.createElement(“script”); script.src = “file.js”; document.body.appendChild(script);
스 크 립 트 를 통 해 비동기 로 삽 입 된 script 태그 의 효 과 는 async 속성 을 가 진 script 태그 와 같다 고 상상 하기 어렵 지 않 습 니 다.스 크 립 트 에 삽 입 된 script 탭 은 기본적으로 async 입 니 다.
또한 내 연 스 크 립 트 에 async 속성 을 설정 하 는 것 은 의미 가 없고 다른 효과 도 나타 나 지 않 습 니 다.포 함 된 스 크 립 트 는 항상 즉시 실 행 됩 니 다.defer 속성
defer 속성 이 있 는 스 크 립 트 는 스 크 립 트 의 실행 을 지연 시 키 고 문서 해석 을 막 지 않 습 니 다.이 스 크 립 트 처럼 문서 의 끝 (이전) 에 놓 여 있 습 니 다.
다음 코드 5 의 거시적인 현상 과 async 속성 을 추가 한 예 는 똑 같 습 니 다. 모두 'A', 'C', 'B' 의 세 개의 alert 를 얻 을 수 있 습 니 다.하지만 그 원 리 는 다르다.
defer 속성 은 스 크 립 트 가 문서 분석 이 끝 난 후에 실 행 될 수 있 도록 확보 합 니 다. 이 스 크 립 트 가 문서 분석 과정 에서 다운로드 가 끝 났 더 라 도 실행 가능 한 상태 가 되 더 라 도 브 라 우 저 는 이 스 크 립 트 의 실행 을 연기 합 니 다. 문서 해석 이 끝 날 때 까지 6, 그리고 DOMContentLoaded 전에 7.
또한 defer 가 있 는 스 크 립 트 는 서로 실행 순 서 를 보장 할 수 있 습 니 다.
defer 속성 은 모든 브 라 우 저 에서 지원 하 는 것 이 아 닙 니 다. 지원 하 는 브 라 우 저 라 도 버 전이 다 르 기 때문에 구체 적 인 행동 이 일치 하지 않 습 니 다.또한, 문서 의 끝 에 script 라벨 을 배치 하 는 간단 한 방법 으로 defer 속성 과 같은 효 과 를 얻 을 수 있 습 니 다.
defer 속성 은 IE4 에서 지원 되 었 으 나 이 defer 속성 은 현대 브 라 우 저의 행동 과 차이 가 있 습 니 다.IE 10 이상 만 이 표준 에 따라 defer 속성 을 실행 하기 시작 합 니 다.async 와 defer 의 영향
W3C 의 공식 문서 8 을 참고 하면 defer 와 async 두 속성 은 서로 영향 을 줄 수 있 습 니 다.
There are three possible modes that can be selected using these attributes. If the async attribute is present, then the script will be executed asynchronously, as soon as it is available. If the async attribute is not present but the defer attribute is present, then the script is executed when the page has finished parsing. If neither attribute is present, then the script is fetched and executed immediately, before the user agent continues parsing the page.
간단 한 귀납:
async ,
defer ,
, ,
규범 에 서 는 두 가지 속성 이 모두 때때로 효과 가 있다 는 것 을 언급 하지 않 았 으 나, 이것 은 문서 에서 허용 되 는 것 이다.이런 구체 적 인 효 과 는 뒤에서 논의 할 것 이다.document. write 의 영향
document. write 는 열 린 문서 흐름 에 문서 내용 을 쓸 수 있 습 니 다.HTML 에 내 장 된 document. write 는 문서 내용 을 추가 할 수 있 습 니 다.document. write 가 script 탭 을 쓰 는 상황 을 고려 하여 9:
실행 순서 가 일반적인 script 태그 와 다 르 지 않 음 을 관찰 합 니 다.설령 네가 삽입 한 라벨 이 async 나 defer 를 가지 고 있다 하 더 라 도 그 행동 은 다 를 바 없다.
고민 되 는 것 은 거꾸로 10 사용 이다.두 번 째 스 크 립 트 는 document. write 를 통 해 기록 되 었 기 때 문 입 니 다.지연 되 는 스 크 립 트 가 실 행 될 때 document 이 닫 혔 습 니 다. document. write 는 아무런 효과 가 없습니다.그래서 defer 를 사용 하 든 async 를 사용 하 든 두 번 째 스 크 립 트 는 실행 되 지 않 았 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
기초 정리 - 1문자 (String) 숫자 (Number) 불린 (Boolean) null undefined 심볼 (Symbol) 큰정수 (BigInt) 따옴표로 묶어 있어야 함 Not-A-Number - 숫자 데이터 / 숫자로 표...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.