欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用jquery模拟a标签的click事件无法实现跳转的解决

程序员文章站 2023-11-22 12:10:22
问题描述 最近在使用jquery模拟a标签的click事件,无法触发其默认行为。即click()或trigger('click')无法触发href跳转。...

问题描述

最近在使用jquery模拟a标签的click事件,无法触发其默认行为。即click()trigger('click')无法触发href跳转。

<a id="abtn" href="https://www.car-me.com/">去卡咪官网</a>
$('#abtn').click();//无法跳转,不生效
$('$abtn').trigger('click');//同样无法跳转,不生效

下面就来一起分析下其原因与解决方法吧

问题原因

jquery内部实现click或trigger方法时,并未真正模拟用户点击事件,只是模拟了事件对象及冒泡的触发。(最后附有jquery实现源码供参考)

解决方案

解决思路:在原生dom触发click事件或利用事件冒泡来解决。

原生dom触发click

<a id="abtn" href="https://www.car-me.com/">去卡咪官网</a>
document.queryselector('#abtn').click();//原生dom触发 或者
$('#abtn')[0].click();//jquery对象转为dom对象再触发

利用子元素事件冒泡

<a id="abtn" href="https://www.car-me.com/">
 <span id="spanbtn">去卡咪官网</span>
</a>
$('#spanbtn').click();//或者
$('#spanbtn').trigger('click');

jquery trigger()实现源码(8159行-8304行)


关键摘要:

// fire handlers on the event path (8237行)
i = 0;
while ( ( cur = eventpath[ i++ ] ) && !event.ispropagationstopped() ) {
	lastelement = cur;
	event.type = i > 1 ?
		bubbletype :
		special.bindtype || type;

	// jquery handler
	handle = ( datapriv.get( cur, "events" ) || {} )[ event.type ] &&
		datapriv.get( cur, "handle" );
	if ( handle ) {
	//******自身trigger('click')或click()时,会调用缓存列表里的事件回调函数,但未执行elem.click()******
		handle.apply( cur, data );
	}

	// native handler
	handle = ontype && cur[ ontype ];
	if ( handle && handle.apply && acceptdata( cur ) ) {
		event.result = handle.apply( cur, data );
		if ( event.result === false ) {
			event.preventdefault();
		}
	}
}
// if nobody prevented the default action, do it now (8263行)
if ( !onlyhandlers && !event.isdefaultprevented() ) {

	if ( ( !special._default ||
		special._default.apply( eventpath.pop(), data ) === false ) &&
		acceptdata( elem ) ) {

		// call a native dom method on the target with the same name as the event.
		// don't do default actions on window, that's where global variables be (#6170)
		if ( ontype && isfunction( elem[ type ] ) && !iswindow( elem ) ) {

			// don't re-trigger an onfoo event when we call its foo() method
			tmp = elem[ ontype ];

			if ( tmp ) {
				elem[ ontype ] = null;
			}

			// prevent re-triggering of the same event, since we already bubbled it above
			jquery.event.triggered = type;

			if ( event.ispropagationstopped() ) {
				lastelement.addeventlistener( type, stoppropagationcallback );
			}
   //******子元素trigger('click')或click(),会执行elem.click()******
			elem[ type ]();

			if ( event.ispropagationstopped() ) {
				lastelement.removeeventlistener( type, stoppropagationcallback );
			}

			jquery.event.triggered = undefined;

			if ( tmp ) {
				elem[ ontype ] = tmp;
			}
		}
	}
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。