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

问题描述

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

去卡咪官网

$('#aBtn').click();//无法跳转,不生效

$('$aBtn').trigger('click');//同样无法跳转,不生效

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

问题原因

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

解决方案

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

原生dom触发click

去卡咪官网

document.querySelector('#aBtn').click();//原生dom触发 或者

$('#aBtn')[0].click();//jquery对象转为dom对象再触发

利用子元素事件冒泡

去卡咪官网

$('#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;

}

}

}

}

总结

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值