이번에는 jQuery의 Read() 메소드가 JS를 대체하는 방법을 보여드리겠습니다. jQuery의 Read() 메소드가 JS를 대체할 때 주의사항은 무엇인가요?
jQuery의 Ready 메소드는 다운로드가 완료되자마자 DOM에 있는 코드를 실행하는 것으로 잘 알려져 있습니다. 주어진 함수를 실행하기 전에 모든 DOM 요소가 로드될 때까지 기다리기 때문에 요소 노드를 작동하고 액세스하려고 시도하는 메서드가 실행된다는 것을 확신할 수 있습니다. 이 기사에서는 기본 JS 대신 jQuery의 Read() 메서드를 사용하는 방법을 소개합니다. jQuery 3.0 버전 이전에는 Ready의 일반적인 사용법은 다음과 같이익명 함수를 사용하는 것이었습니다.
$(document).ready(function() { // Handler for .ready() called. });
jQuery 3.0 Ready() 변경 사항
jQuery 3.0이 출시되기 전에는 다음과 같은 사항이 있었습니다. 다음 메소드: 준비된 메소드입니다: 문서 요소에 대한 작업: $(document).ready(handler);
$(document).ready(handler);
在空元素上操作: $().ready(handler);
或者直接(即不在一个具体的元素上)操作: $(handler);
上述所有命名的变种在功能上是等价的。无论是哪个元素,在DOM加载完毕之后其指定的处理程序都将会被调用。换句话说,这里的DOM加载完毕并不表示在文档中的某个具体的元素,比如img元素,加载完毕。相反,这里表示的是整个DOM树加载完毕。
在jQuery 3.0中,除了$(handler)
其他的ready方法都被弃用。
官方声明为此:
这是因为选择器并没有和ready()建立联系,不仅低效而且会导致浏览器引擎对该方法的行为进行不正确的假设。
ready 事件和 load 事件的区别
当DOM加载完毕且元素能够被安全访问时就会触发ready事件。另一方面,load事件却在DOM和所有资源加载后触发。
可以像下面这样使用load事件:
$(window).on("load", function(){ // Handler when all assets (including images) are loaded });
这样的话,不仅仅要等到DOM结构能完全访问,而且还需要等到所有的图片资源完全加载完毕(加载时间取决于图片文件大小)才能执行函数。
正常的DOM操作你可能不需要load事件,但是如果你想要在所有的资源被加载完毕之前展示一个旋转的加载器样式,比如,又或者你想要用JS计算一下图片的大小,这可能是一个好的选择。
你可能不需要jQuery.ready()
ready 方法可以确保代码只在所有DOM元素能被安全操纵时才执行。 但这意味着什么呢?这意味着当你要执行的js代码嵌在HTML中某个片段中时,浏览器也要加载完以下元素才能执行。
就像下面这个例子一样:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>.ready() tutorial</title> <script src="https://cdn.jsdelivr.net/jquery/latest/jquery.min.js"></script> <script> $(function(){ // .ready() callback, is only executed when the DOM is fully loaded var length = $("p").length; // The following will log 1 to the console, as the paragraph exists. // This is the evidence that this method is only called when the // DOM is fully loaded console.log(length); }); </script> </head> <body> <p>I'm the content of this website</p> </body> </html>
如果你要执行的javascript代码放在body末尾,你就可能不需要使用ready()
方法,因为浏览器解析到javascript时你可能试图操纵和访问的DOM元素已经被加载完了:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>.ready() tutorial</title> </head> <body> <p>I'm the content of this website</p> <script src="https://cdn.jsdelivr.net/jquery/latest/jquery.min.js"></script> <script> var length = $("p").length; // The following will log 1 to the console, as the paragraph exists. console.log(length); </script> </body> </html>
原生JavaScript ready()替代
对于现代浏览器以及IE9+,你可以通过监听 DOMContentLoaded 事件实现ready()
빈 요소에 대한 작업: $().ready (handler);
또는 직접 작동합니다(예: 특정 요소가 아님): $(handler);
위에 명명된 모든 변형은 기능적으로 동일합니다. 어떤 요소이든지 DOM이 로드된 후에 지정된 핸들러가 호출됩니다. 즉, 여기서 DOM 로딩이 완료되었다고 해서 img 요소와 같은 문서의 특정 요소가 로드되었다는 의미는 아닙니다. 반대로 여기서 의미하는 것은 전체 DOM 트리가 로드되었다는 것입니다.
jQuery 3.0에서는 $(handler)
를 제외한 모든 준비된 메서드가 더 이상 사용되지 않습니다.
공식 성명: 이것은 선택기가 Ready()에 연결되어 있지 않기 때문입니다. 이는 비효율적일 뿐만 아니라 브라우저 엔진이 이 메서드의 동작에 대해 잘못된 가정을 하게 만듭니다.
준비 이벤트와 로드 이벤트의 차이점
🎜🎜🎜준비 이벤트는 DOM이 로드되고 요소에 안전하게 액세스할 수 있을 때 트리거됩니다. 반면에 로드 이벤트는 DOM과 모든 리소스가 로드된 후에 트리거됩니다. 🎜🎜다음과 같이 로드 이벤트를 사용할 수 있습니다. 🎜document.addEventListener("DOMContentLoaded", function(){ // Handler when the DOM is fully loaded });
var callback = function(){ // Handler when the DOM is fully loaded }; if ( document.readyState === "complete" || (document.readyState !== "loading" && !document.documentElement.doScroll) ) { callback(); } else { document.addEventListener("DOMContentLoaded", callback); }
ready()
메서드를 사용할 필요가 없을 수도 있습니다. 🎜document.attachEvent("onreadystatechange", function(){ // check if the DOM is fully loaded if(document.readyState === "complete"){ // remove the listener, to make sure it isn't fired in future document.detachEvent("onreadystatechange", arguments.callee); // The actual handler... } });
ready()
와 동일한 기능을 얻을 수 있습니다. 🎜rrreee🎜 그러나 참고하세요 이벤트가 이미 발생한 경우 콜백이 실행되지 않습니다. 콜백이 항상 실행되도록 하기 위해 jQuery는 문서 참조의 "readyState" 속성을 확인하고 속성 값이 완료되도록 변경되면 즉시 🎜콜백 함수🎜를 실행합니다. 🎜rrreee🎜에는 이 솔루션을 구현한 domReady 라이브러리가 포함되어 있습니다. 🎜🎜🎜🎜🎜IE 브라우저의 이전 버전🎜🎜🎜🎜🎜브라우저 IE8 이하의 경우 onreadystatechange 이벤트를 사용하여 문서의 ReadyState 속성을 모니터링할 수 있습니다. 🎜document.attachEvent("onreadystatechange", function(){ // check if the DOM is fully loaded if(document.readyState === "complete"){ // remove the listener, to make sure it isn't fired in future document.detachEvent("onreadystatechange", arguments.callee); // The actual handler... } });
或者你可以使用Load事件,如jQuery,这样可以在任何浏览器上运行。这也会导致一个时间延迟,因为它会等待所有的资产被加载。
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
위 내용은 JS를 jQuery의 Read() 메서드로 바꾸는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!