JQuery与JS里submit()的区别示例介绍

Camille ·
更新时间:2024-09-21
· 509 次阅读

ASP.NET 的服务器控件回发是使用这一段JS代码:
代码如下:
var theForm = document.forms['form1'];
if (!theForm) {
theForm = document.form1;
}
function __doPostBack(eventTarget, eventArgument) {
if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
theForm.__EVENTTARGET.value = eventTarget;
theForm.__EVENTARGUMENT.value = eventArgument;
theForm.submit();
}
}

今天遇到的问题是想在服务器端控件回发之前给其中一个隐藏域赋值,以给服务器传值。
于是就用JQuery的 submit([[data],fn]) 方法添加了一个事件,但发现不起作用。
我用 $("form:first").submit() 试了一下,发现能触发事件函数。
怎么回事呢?查了一下资料发现js的原生函数 void submit() 并不触发submit事件。这也是为什么上面那段代码里有
代码如下:
if (<span style="color:#006600">!theForm.onsubmit || (theForm.onsubmit() != false</span>)) {
...
}

这句了。
于是把添加事件写成
代码如下:
$("form:first")<span style="color:#006600">.get(0)</span>.onsubmit = function () {
...
};

就可以啦。
另外,用JQuery的 submit([[data],fn]) 添加的事件是可以用 $().submit() 触发的。



示例 submit js jQuery

需要 登录 后方可回复, 如果你还没有账号请 注册新账号