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

首頁 > 編程 > JavaScript > 正文

Javascript 模擬點(diǎn)擊事件(點(diǎn)擊鏈接與html點(diǎn)擊) 兼容IE/Firefox

2019-11-21 00:50:38
字體:
供稿:網(wǎng)友

一把情況下模擬點(diǎn)擊一般兩個(gè)方面,模擬點(diǎn)擊超級連接事件
firefox的兼容的函數(shù)為
對HTMLAnchorElement 加入onclick事件

復(fù)制代碼 代碼如下:

try {
// create a element so that HTMLAnchorElement is accessible
document.createElement('a');
HTMLElement.prototype.click = function () {
if (typeof this.onclick == 'function') {
if (this.onclick({type: 'click'}) && this.href)
window.open(this.href, this.target? this.target : '_self');
}
else if (this.href)
window.open(this.href, this.target? this.target : '_self');
};
}
catch (e) {
// alert('click method for HTMLAnchorElement couldn/'t be added');
}

下面是具體的應(yīng)用

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]

如果是普通的html添加點(diǎn)擊
這一段使得FireFox的HTMLElement具有click方法(add click method to HTMLElement in Mozilla)
復(fù)制代碼 代碼如下:

try {
// create span element so that HTMLElement is accessible
document.createElement('span');
HTMLElement.prototype.click = function () {
if (typeof this.onclick == 'function')
this.onclick({type: 'click'});
};
}
catch (e) {
// alert('click method for HTMLElement couldn/'t be added');
}

下面是網(wǎng)友的其它相關(guān)文章也可以參考下。
最近做東西發(fā)現(xiàn)用戶在網(wǎng)頁輸入框里面按回車的行為是不固定的。。。
特別是在網(wǎng)頁有多個(gè)表單的時(shí)候
于是搜了一把找了一個(gè)模擬點(diǎn)擊的js,經(jīng)測試能在firefox和ie上運(yùn)行
復(fù)制代碼 代碼如下:

function doClick(linkId, e){
if(e.keyCode != 13){
return;
}
var fireOnThis = document.getElementById(linkId)
if (document.createEvent)
{
var evObj = document.createEvent('MouseEvents')
evObj.initEvent( 'click', true, false )
fireOnThis.dispatchEvent(evObj)
}
else if (document.createEventObject)
{
fireOnThis.fireEvent('onclick')
}
}

其中e是event,內(nèi)置對象,linkId是模擬被點(diǎn)擊的對象id
比如<INPUT id="test" onkeypress="doClick("buttonId", event)">
這樣的話就能讓用戶按回車來提交表單了~
opera可以再改一下
復(fù)制代碼 代碼如下:

<img id="a" src="/a.jpg" onclick="alert('a');"/><div onclick="clickObj('a')">click me</div>
<script language="javascript">
<!--
function clickObj(o){
var o = document.getElementById(o);
if( document.all && typeof( document.all ) == "object" ) //IE
{
o.fireEvent("onclick");
}
else
{
var e = document.createEvent('MouseEvent');
e.initEvent('click',false,false);
o.dispatchEvent(e);
}
}
//-->
</script>

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 龙陵县| 建宁县| 苍梧县| 阿勒泰市| 科尔| 勃利县| 道孚县| 秦安县| 成都市| 乌恰县| 新民市| 桃江县| 巴中市| 盐亭县| 巴中市| 龙井市| 巴中市| 阿勒泰市| 新田县| 任丘市| 和硕县| 松阳县| 达日县| 青冈县| 敦化市| 安远县| 来宾市| 商水县| 东乡族自治县| 南安市| 霍林郭勒市| 隆昌县| 呼伦贝尔市| 伊金霍洛旗| 武威市| 乌拉特后旗| 扶风县| 乌兰察布市| 平定县| 鄢陵县| 定结县|