国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:27:33
字體:
來源:轉載
供稿:網(wǎng)友

問題描述

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

<a id="aBtn" );//同樣無法跳轉,不生效

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

問題原因

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

解決方案

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

原生dom觸發(fā)click

<a id="aBtn" ).click();//原生dom觸發(fā) 或者$('#aBtn')[0].click();//jquery對象轉為dom對象再觸發(fā)

利用子元素事件冒泡

<a id="aBtn" > <span id="spanBtn">去卡咪官網(wǎng)</span></a>$('#spanBtn').click();//或者$('#spanBtn').trigger('click');

jquery trigger()實現(xiàn)源碼(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()時,會調(diào)用緩存列表里的事件回調(diào)函數(shù),但未執(zhí)行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(),會執(zhí)行elem.click()******			elem[ type ]();			if ( event.isPropagationStopped() ) {				lastElement.removeEventListener( type, stopPropagationCallback );			}			jQuery.event.triggered = undefined;			if ( tmp ) {				elem[ ontype ] = tmp;			}		}	}}            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 崇礼县| 大丰市| 达拉特旗| 孝义市| 胶州市| 永寿县| 东光县| 承德市| 松潘县| 三门峡市| 察雅县| 三河市| 博罗县| 鄱阳县| 黄山市| 新民市| 凌云县| 金平| 青岛市| 鹿邑县| 昂仁县| 博湖县| 左权县| 民权县| 五华县| 仁化县| 山阳县| 昭觉县| 博野县| 武平县| 宁蒗| 枞阳县| 文安县| 林西县| 栾城县| 纳雍县| 霸州市| 双鸭山市| 宾川县| 阳原县| 时尚|