> 웹 프론트엔드 > JS 튜토리얼 > jquery on과 바인딩의 차이점은 무엇입니까?

jquery on과 바인딩의 차이점은 무엇입니까?

coldplay.xixi
풀어 주다: 2020-11-30 15:06:57
원래의
2944명이 탐색했습니다.

jquery on과 바인드의 차이점: 1. 바인드 메소드는 각 하위 요소에 이벤트를 추가하며 이는 성능에 영향을 미치지만 on 메소드는 그렇지 않습니다. 2. 바인드가 요소를 동적으로 추가할 때 이벤트를 동적으로 바인드할 수는 없지만 on 메소드는 가능합니다.

jquery 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>
로그인 후 복사

사용법:

$(&#39;div p&#39;).bind(&#39;click&#39;,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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿