91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用jquery模擬a標簽的click事件無法實現跳轉的解決

發布時間:2020-10-08 12:26:02 來源:腳本之家 閱讀:233 作者:單騎入西蜀 欄目:web開發

問題描述

最近在使用jquery模擬a標簽的click事件,無法觸發其默認行為。即click()trigger('click')無法觸發href跳轉。

<a id="aBtn" >去卡咪官網</a>
$('#aBtn').click();//無法跳轉,不生效
$('$aBtn').trigger('click');//同樣無法跳轉,不生效

下面就來一起分析下其原因與解決方法吧

問題原因

jquery內部實現click或trigger方法時,并未真正模擬用戶點擊事件,只是模擬了事件對象及冒泡的觸發。(最后附有jquery實現源碼供參考)

解決方案

解決思路:在原生dom觸發click事件或利用事件冒泡來解決。

原生dom觸發click

<a id="aBtn" >去卡咪官網</a>
document.querySelector('#aBtn').click();//原生dom觸發 或者
$('#aBtn')[0].click();//jquery對象轉為dom對象再觸發

利用子元素事件冒泡

<a id="aBtn" >
 <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;
			}
		}
	}
}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

靖江市| 怀化市| 广水市| 曲麻莱县| 长乐市| 樟树市| 运城市| 邢台县| 广汉市| 克山县| 黔东| 天长市| 永昌县| 商河县| 民乐县| 长治县| 阿拉善左旗| 余庆县| 萨迦县| 盐池县| 嘉义县| 漾濞| 武清区| 漠河县| 张北县| 黑山县| 财经| 南投县| 阳谷县| 珲春市| 平原县| 大港区| 望谟县| 肥东县| 乌拉特前旗| 九台市| 通山县| 陆良县| 兴化市| 新营市| 长岭县|