>웹 프론트엔드 >JS 튜토리얼 >jquery의 Trigger()가 hover event_jquery를 트리거할 수 없는 문제에 대한 솔루션

jquery의 Trigger()가 hover event_jquery를 트리거할 수 없는 문제에 대한 솔루션

WBOY
WBOY원래의
2016-05-16 16:00:251220검색

오늘 프로젝트를 진행하다가 이전에 겪어보지 못한 문제에 직면해서 메모해 두었습니다.

1. 트리거 방식 설명

공식 설명은 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

설명: 해당 이벤트 유형에 대해 일치하는 요소에 연결된 모든 핸들러 및 동작을 실행합니다.

사용법:
.trigger( eventType [, extraParameters] )

eventType에는 자바스크립트 내장 이벤트, jQuery 추가 이벤트, 맞춤 이벤트가 포함됩니다. 예:

$('#foo').bind('click', function()
{
 alert($(this).text());
});
$('#foo').trigger('click');
$('#foo').bind('custom', function(event, param1, param2)
{
 alert(param1 + "\n" + param2);
});
$('#foo').trigger('custom', ['Custom', 'Event']);

은 매우 강력하며 페이지 초기화 중에 자주 사용됩니다.

2. 트리거와 호버의 만남

var $search=$('#header .search');
$search.find('li').hover(function()
{
 alert(1);
},function()
{
 alert(2);
});
$search.find('li').eq(0).trigger('hover');

호버를 실행할 수 없습니다. 하지만:

var $search=$('#header .search');
$search.find('li').click(function()
{
 alert(1);
},function()
{
 alert(2);
});
$search.find('li').eq(0).trigger('click');

클릭이 발생하는 것은 정상입니다!

해결책:

var $search=$('#header .search');
$search.find('li').hover(function()
{
 alert(1);
},function()
{
 alert(2);
});
$search.find('li').eq(0).trigger('mouseenter');//hover修改为mouseenter/mouseleave/mouseover/mouseout

jQuery.live()에도 동일한 상황이 있지만 1.7 이후 버전에서는 live를 사용하지 않는 것이 좋습니다. 대신 on()을 사용하세요.

위 내용은 이 글의 전체 내용입니다. 모두 마음에 드셨으면 좋겠습니다.

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