찾다
웹 프론트엔드프런트엔드 Q&Ajquery $(document).ready() 와 onload의 차이점은 무엇입니까

차이점: window.onload에는 간단한 작성 방법이 없습니다. 이미지를 포함한 페이지의 모든 요소가 로드될 때까지 기다려야 실행될 수 있습니다. 그리고 "$(document).ready()"는 "$(function(){})"로 축약될 수 있는데, 이는 DOM 구조가 로드될 때까지 기다리지 않고 DOM 구조가 그려진 후에 실행됩니다.

jquery $(document).ready() 와 onload의 차이점은 무엇입니까

추천 튜토리얼: jquery 비디오 튜토리얼

jquery $(document).ready()와 window.onload의 차이점

1. window.onload는 반드시 wait wait는 이미지를 포함한 페이지의 모든 요소가 로드된 후에만 실행될 수 있습니다. $(document).ready()는 DOM 구조가 그려진 후 로드될 때까지 기다릴 필요 없이 실행됩니다.


2. 쓰기 횟수가 다릅니다.

window.onload는 동시에 여러 번 작성할 수 없습니다.

$(문서). Ready()는 동시에 여러 번 작성할 수 있으며 모두 실행할 수 있습니다

3. 단순화된 작성

window.onload 단순화된 작성이 없습니다

$(document).ready(function(){} )는 $(function(){});

지침:

문서를 로드하는 브라우저를 예로 들어 보겠습니다. 페이지가 로드된 후 브라우저는 JavaScript를 통해 DOM 요소에 이벤트를 추가합니다. 일반 JavaScript 코드에서는 주로 window.onload 메서드를 사용하지만, jQuery에서는 $(document).ready() 메서드를 사용합니다.

$(document).ready() 메소드와 window.onload 메소드는 기능은 비슷하지만 실행 시점에 차이가 있습니다. window.onload 메소드는 웹 페이지의 모든 요소(요소의 관련 파일 포함)가 브라우저에 완전히 로드된 후에 실행됩니다. 즉, JavaScript는 현재 웹 페이지의 모든 요소에만 액세스할 수 있습니다. jQuery에서 $(document).ready() 메소드를 통해 등록된 이벤트 핸들러는 DOM이 완전히 준비되면 호출할 수 있습니다. 이 시점에서 웹 페이지의 모든 요소는 jQuery에 액세스할 수 있지만 이것이 해당 요소와 관련된 파일이 다운로드되었다는 의미는 아닙니다.

예를 들어, 웹 페이지의 모든 사진에 특정 동작(예: 사진을 클릭하면 사진을 숨기거나 표시하는 등)을 추가하는 대형 사진 갤러리 웹사이트가 있습니다. window.onload 메서드를 사용하는 경우 사용자는 계속 진행하기 전에 각 이미지가 로드될 때까지 기다려야 합니다. jQuery에서 $(document).ready() 메소드를 사용하여 설정하면 모든 이미지가 다운로드될 때까지 기다리지 않고 DOM이 준비되는 즉시 작동할 수 있습니다. 분명히 웹페이지를 DOM 트리로 구문 분석하는 것은 웹페이지에 관련된 모든 파일을 로드하는 것보다 훨씬 빠릅니다.

또 주의할 점은 $(document).ready() 메소드에 등록된 이벤트는 DOM이 준비된 상태에서만 실행되기 때문에 이때 해당 요소의 관련 파일이 다운로드되지 않을 수 있다는 점입니다. 예를 들어, 이미지와 관련된 HTML을 다운로드하여 DOM 트리로 파싱했지만, 이미지가 아직 로드되지 않았을 가능성이 높으므로 이때 이미지의 높이, 너비 등의 속성이 유효하지 않을 수 있습니다. 시간. 이 문제를 해결하려면 JQuery의 또 다른 페이지 로딩 메소드인 load() 메소드를 사용할 수 있습니다. load() 메서드는 핸들러 함수를 요소의 onload 이벤트에 바인딩합니다. 핸들러 함수가 창 개체에 바인딩된 경우 모든 콘텐츠(창, 프레임, 개체, 이미지 등 포함)가 로드된 후에 트리거됩니다. 요소의 콘텐츠가 로드됩니다. jQuery 코드는 다음과 같습니다.

$(window).load(function () {
    //编写代码
})

JavaScript의 다음 코드와 동일합니다.

window.onload = function () {
    //编写代码
}

웹 페이지에 두 개의 함수가 있다고 가정하면 JavaScript 코드는 다음과 같습니다.

function one() {
    alert("one");
}
function two() {
    alert("two");
}

웹 페이지가 로드되면 하나의 함수가 function과 two는 각각 자바스크립트 코드를 통해 호출됩니다. Function:

window.onload = one;
window.onload = two;

그런데 코드를 실행한 후 문자열 "two" 대화 상자만 나타나는 것을 발견했습니다.

문자열 "one" 대화 상자가 표시되지 않는 이유는 JavaScript의 onload 이벤트가 한 번에 하나의 함수에 대한 참조만 저장할 수 있기 때문입니다. 자동으로 이전 함수를 이후 함수로 덮어쓰므로 추가할 수 없습니다. 기존 행동에.

두 함수의 순차적 트리거 효과를 얻으려면 새로운 JavaScript 메서드를 생성해야만 얻을 수 있습니다. JavaScript 코드는 다음과 같습니다.

window.onload = function () {
    one();
    two();
}

이런 방식으로 작성된 코드는 특정 문제를 해결할 수 있지만 여전히 특정 요구 사항을 충족할 수 없습니다. 예를 들어, 여러 개의 JavaScript 파일이 있고 각 파일은 window.onload 메서드를 사용해야 합니다. 이 경우 위에서 언급한 방법을 사용하여 코드를 작성하는 것은 매우 번거로운 작업입니다. Javascript 공유 onload 이벤트를 참조할 수 있으며 jQuery의 $(document).ready() 메서드는 이러한 상황을 잘 처리할 수 있습니다. $(document).ready() 메서드를 호출할 때마다 기존 동작에 새로운 동작이 추가됩니다. , 이러한 동작 함수는 등록된 순서에 따라 순차적으로 실행됩니다. 예를 들어 다음 jQuery 코드는 다음과 같습니다.

function one() {
    alert("one");
}
function two() {
    alert("two");
}
$(document).ready(function () {
    one();
});
$(document).ready(function () {
    two();
})

코드를 실행하면 "one"이라는 문자열 대화 상자가 나타나고, 이어서 "two"라는 문자열 대화 상자가 나타납니다.

더 많은 프로그래밍 관련 지식을 보려면 다음 페이지를 방문하세요. :

프로그래밍 튜토리얼

! !

위 내용은 jquery $(document).ready() 와 onload의 차이점은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
기능 반응 구성 요소에서 usestate () 후크를 사용하는 방법기능 반응 구성 요소에서 usestate () 후크를 사용하는 방법Apr 30, 2025 am 12:25 AM

usestate는 클래스 구성 요소와 기능 구성 요소 사이의 장애물을 제거하기 때문에 함수 구성 요소에 상태를 추가 할 수 있도록하여 후자를 동일하게 강력하게 만듭니다. usestate를 사용하기위한 단계에는 다음이 포함됩니다. 1) usestate hook 가져 오기, 2) 상태 초기화, 3) 상태 사용 및 기능 업데이트.

React의 관점 ​​중심 특성 : 복잡한 응용 프로그램 상태 관리React의 관점 ​​중심 특성 : 복잡한 응용 프로그램 상태 관리Apr 30, 2025 am 12:25 AM

React의 View Focus는 추가 도구와 패턴을 도입하여 복잡한 응용 프로그램 상태를 관리합니다. 1) RECT 자체는 상태 관리를 처리하지 않으며 상태를 촬영하는 데 중점을 둡니다. 2) 복잡한 응용 프로그램은 Redux, Mobx 또는 ContextApi를 사용하여 상태를 분리하여 관리를보다 체계적이고 예측할 수 있도록해야합니다.

다른 라이브러 및 프레임 워크와 반응을 통합합니다다른 라이브러 및 프레임 워크와 반응을 통합합니다Apr 30, 2025 am 12:24 AM

integratingReactwitherLibrariesandFrameworkScanEnHanceApplicationCapabilitiesBeveragingDifferentTools'Strengths.benefitsinCludeStreamLinedStameManagement WithReduxAndRobStatemEntegrationwithdjango, butchallEngesInvolveNcreatedComePlexity, perfo

REACT를 사용한 접근성 고려 사항 : 포용 적 UI 건물REACT를 사용한 접근성 고려 사항 : 포용 적 UI 건물Apr 30, 2025 am 12:21 AM

tomaerkeActApplicationSmoreAccessible, followthesesteps : 1) audeEmantichtmlementsInjsxForBetTernAvigationAndSeo.2) ubstractFocusManagementForKeyboardUsers, 특히 인종상 3) utilizereAcths -likeUseefectTeMangemanmamicContentChangeAlivergio

React와의 SEO 문제 : 클라이언트 측 렌더링 문제 해결React와의 SEO 문제 : 클라이언트 측 렌더링 문제 해결Apr 30, 2025 am 12:19 AM

RECT 응용 프로그램 용 SEO는 다음 방법으로 해결할 수 있습니다. 1. SSR (Server-Side Rendering) 구현 (예 : Next.js); 2. Prerender.io 또는 Puppeteer를 통한 사전 렌더링 페이지와 같은 동적 렌더링을 사용하십시오. 3. 응용 프로그램 성능을 최적화하고 성능 감사를 위해 등대를 사용하십시오.

React의 강력한 커뮤니티 및 생태계의 이점React의 강력한 커뮤니티 및 생태계의 이점Apr 29, 2025 am 12:46 AM

React'sstrongcommunityandecosystemoffernumerousbenefits : 1) impliceAccesstosolutionsThroughplatformslikestackOverflowandGitHub; 2) exealthoflibrariesandTools, walsuicomponentlibrarieslikeChakraui, thatenhancedevelopmenticificients; 3)

모바일 개발을위한 기본 반응 : 크로스 플랫폼 앱 구축모바일 개발을위한 기본 반응 : 크로스 플랫폼 앱 구축Apr 29, 2025 am 12:43 AM

reftnativeIschosenFormoBiledevelopmentBecauseItAllowsDeveloperstowRiteCodeOndDeployIntonMultiplePlatforms, DevelopmentTimeAndCosts.itoffersnear-NativePerformance, AthrivingCommunity, AndleverAgesexistingWebDevelopmentsKills.keyTomasteringRea

React의 usestate ()로 상태를 올바르게 업데이트합니다React의 usestate ()로 상태를 올바르게 업데이트합니다Apr 29, 2025 am 12:42 AM

RECT에서 usestate () 상태의 올바른 업데이트는 상태 관리의 세부 사항을 이해해야합니다. 1) 기능 업데이트를 사용하여 비동기 업데이트를 처리합니다. 2) 상태를 직접 수정하지 않도록 새 상태 객체 또는 배열을 만듭니다. 3) 단일 상태 객체를 사용하여 복잡한 양식을 관리하십시오. 4) 셰이크 방지 기술을 사용하여 성능을 최적화하십시오. 이러한 방법은 개발자가 일반적인 문제를 피하고보다 강력한 반응 응용 프로그램을 작성하는 데 도움이 될 수 있습니다.

See all articles

핫 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 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음