>웹 프론트엔드 >JS 튜토리얼 >동적으로 추가된 요소와 함께 Fancybox를 사용하는 방법은 무엇입니까?

동적으로 추가된 요소와 함께 Fancybox를 사용하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-17 06:10:03657검색

How to Use Fancybox with Dynamically Added Elements?

Fancybox를 동적으로 추가된 요소에 바인딩

Fancybox v1.3.4를 문서에 동적으로 추가된 요소와 함께 사용하면 문제가 발생할 수 있습니다. 이는 Fancybox가 정적 요소에만 바인딩되기 때문입니다.

해결책:

1단계: jQuery v1.7.x로 업그레이드

이 버전에는 동적으로 추가된 요소에 이벤트를 바인딩할 수 있는 .on() 메서드가 포함되어 있습니다.

2단계: .on() 및 focusin 이벤트 사용

fancybox 요소의 상위 요소에 .on() 메서드를 바인딩합니다. focusin 이벤트는 Fancybox가 상위 컨테이너의 포커스 내에 있는 요소에만 바인딩되도록 하는 데 사용됩니다.

예를 들어 Fancybox 요소에 "ajaxFancyBox" 클래스가 있고 ID가 "container"인 컨테이너 내에 있는 경우 ":

$("#container").on("focusin", function() {
  $("a.ajaxFancyBox").fancybox({
    // Set your Fancybox options here
  });
});

이 방법은 다양한 콘텐츠 유형에 대해 다양한 Fancybox 옵션 지정도 지원합니다.

$("#container").on("focusin", function() {
  $("a.ajaxFancyBox").fancybox({
    // Ajax options
  });

  $("a.iframeFancyBox").fancybox({
    // Iframe options
  });
});

Chrome에 대한 중요 참고 사항:

Chrome에서는 on() 메서드가 작동하려면 Fancybox에 바인딩된 모든 요소에 tabindex 속성을 추가해야 합니다.

<a tabindex="1" class="ajaxFancyBox" href="image01.jpg">...</a>
<a tabindex="1" class="ajaxFancyBox" href="image02.jpg">...</a>

이 솔루션은 새 콘텐츠를 추가하고 기존 콘텐츠를 바꾸는 데 모두 작동합니다. .on() 메소드가 적용된 컨테이너 내에 새로운 컨텐츠가 추가되었는지 확인하세요.

위 내용은 동적으로 추가된 요소와 함께 Fancybox를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.