表单Form的submit事件不响应

限量版♂猪崽

限量版♂猪崽

2016-02-19 12:49

图老师小编精心整理的表单Form的submit事件不响应希望大家喜欢,觉得好的亲们记得收藏起来哦!您的支持就是小编更新的动力~


一、问题描述
当用JS调用form的方法submit直接提交form的时候,submit事件不响应。为什么?知道的请回复。类比一下,我用input.select()做了测试,却能响应select事件。这个原因先放一边,我们看看先怎么把眼下的问题解决了。
不响应事件的代码示例:
form id="form1" action="http://m.tulaoshi.com"/form
script type="text/javascript"
var form = document.getElementById('form1');
form.onsubmit = function() {
alert(1);
};
form.submit();
/script
实际运行,不会有alert出来。
虽然用submit方法来提交表单有违Unobtrustive Javascript的原则,但有时候不得不用,比如做搜索提示(auto-complete)选中Item之后就需要用JS来提交搜索表单。
二、问题分析
既然本身不响应事件,那只有手工触发这些事件了,确定手工触发方案之前先回顾一下事件的注册方式:
原始的注册方式有两种,看代码示例:
form id="form1" action="http://m.tulaoshi.com" onsubmit="alert(1)"/formform id="form1" action="http://m.tulaoshi.com"/form
script type="text/javascript"
document.getElementById('form1').onsubmit = function() {
alert(1);
}
/script
这样的注册事件,会给form增加了一个方法onsubmit。所以,可以通过直接执行这个方法,等同于手工触发了事件。
看代码示例:
script type="text/javascript"
form.onsubmit();
/script
这样可以得到一个alert。
但是在如今先进的DOM2标准注册方式以及IE的注册方式attachEvent已经很常用。这些注册方式,onsubmit方法是不存在的,如果使用form.onsubmit()会直接报错。
三、解决方案
当然先进的注册方式本身也提供了手工触发事件的解决方案,只是要针对DOM2标准和IE写不同的程序,另外这个程序,对原始的注册方式也一样有效。请看代码示例:
script type="text/javascript"
//IE fire event
if (form.fireEvent) {
form.fireEvent('onsubmit');
form.submit();
//DOM2 fire event
} else if (document.createEvent) {
var ev = document.createEvent('HTMLEvents');
ev.initEvent('submit', false, true);
form.dispatchEvent(ev);
}
/script
四、代码总结
这里不再对各细节方法做说明,不熟悉的朋友请自行查阅相关资料。我们把整个代码串起来:
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"
html
head
meta http-equiv="Content-Type" content="text/html; charset=GBK"
titlesubmit/title
script type="text/javascript" src="http://k.kbcdn.com/js/yui/build/utilities/utilities.js"/script
/head
body
form id="form1" action="http://m.tulaoshi.com"/form
script type="text/javascript"
var form = document.getElementById('form1');
//YUI register event
YAHOO.util.Event.on('form1', 'submit', function() {
alert('yui');
});
//DOM0 register event
form.onsubmit = function() {
alert(1);
};
//DOM2 register event
if (form.addEventListener) {
form.addEventListener('submit', function() {
alert(2);
}, false);
//IE register event
} else if (form.attachEvent) {
form.attachEvent('onsubmit', function() {
alert(2);
});
}
//IE fire event
if (form.fireEvent) {
form.fireEvent('onsubmit');
form.submit();
//DOM2 fire event
} else if (document.createEvent) {
var ev = document.createEvent('HTMLEvents');
ev.initEvent('submit', false, true);
form.dispatchEvent(ev);
}
/script
/body
/html
整个跑下来有个小问题,FX下,不需要form.submit(),直接把表单给提交出去了,所以这句也省掉了,原因知道的请回复。
这个demo在IE6/IE7/FX下测试通过。

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)
展开更多 50%)
分享

猜你喜欢

表单Form的submit事件不响应

Web开发
表单Form的submit事件不响应

Applet事件响应

编程语言 网络编程
Applet事件响应

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

VisualBasic制作透明的表单(Form)

编程语言 网络编程
VisualBasic制作透明的表单(Form)

CSS form表单布局经典一例

Web开发
CSS form表单布局经典一例

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

关于TButton类型不能响应OnDBClick事件

编程语言 网络编程
关于TButton类型不能响应OnDBClick事件

浅议Web网页Form表单设计技巧

Web开发
浅议Web网页Form表单设计技巧

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

生成GBK码表

生成GBK码表

SOAP应用简介

SOAP应用简介
下拉加载更多内容 ↓