jquery on과 바인드의 차이점: 1. 바인드 메소드는 각 하위 요소에 이벤트를 추가하며 이는 성능에 영향을 미치지만 on 메소드는 그렇지 않습니다. 2. 바인드가 요소를 동적으로 추가할 때 이벤트를 동적으로 바인드할 수는 없지만 on 메소드는 가능합니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, jquery 버전 1.10.2 이 방법은 모든 브랜드의 컴퓨터에 적합합니다.
jquery on과 바인딩의 차이점:
on() 메서드 소스 코드를 보면 bind()
与delegate()
하단 레이어는 on() 메서드를 사용하여 구현됩니다.
함수 서명: 바인딩(type, [ data], fn), on( type,[selector],[data],fn) .
예:
<html> <head> <meta charset="UTF-8"> <title></title> <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script> </head> <body> <div> <button id="add">添加新的p元素</button> <p>第一个p元素</p> <p>第二个p元素</p> <p>第三个p元素</p> <p>第四个p元素</p> <p>第五个p元素</p> </div> <script> $("#add").click(function(){ $("div").append("<p>这是一个新的p元素</p>"); }); </script>
사용법:
$('div p').bind('click',function(){ alert($(this).text()); }) $("div").on("click","p",function(){ alert($(this).text()); })
장점과 단점 비교:
bind() 메서드:
단점:
1. 하위 요소가 너무 많으면 각 하위 요소에 이벤트를 추가하면 성능에 영향을 미칩니다.
2 요소를 동적으로 추가하면 이벤트를 동적으로 바인딩할 수 없습니다.
장점: 이벤트를 단일 요소에 바인딩할 때 작성하는 것이 편리합니다.( 무시)
on() 메서드:
1. 위의 두 가지 단점을 해결합니다.
2. 이벤트를 직접 바인딩하는 대신 이벤트 위임 메커니즘을 사용합니다. p 요소이지만 상위 요소(또는 상위 요소)에 이벤트를 바인딩할 수 있습니다. div 내의 요소를 클릭하면 해당 요소에 도달할 때까지 이벤트가 레이어별로 이벤트 대상에서 버블링됩니다.
3. 호출되는 문제도 수시로 발생할 수 있습니다. 이벤트 대상이 DOM 트리에 매우 깊은 경우 선택기와 일치하는 요소를 찾기 위해 레이어별로 버블링하면 성능에 영향을 미칩니다.
요약:
1. 반복적으로 바인딩하려면 바인딩()을 사용하지 마세요
2. id 선택기를 사용할 때는 바인딩()
을 사용할 수 있습니다. 3. 동적으로 추가된 요소를 바인딩해야 하는 경우에는 위임() 또는 on()을 사용하세요
4. Delegate() 및 on() 메서드를 사용하고 DOM 트리가 너무 깊어서는 안 됩니다.
5. on()
을 사용해 보세요. 관련 무료 학습 권장 사항: javascript(동영상)
위 내용은 jquery on과 바인딩의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!