加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 教程 > 正文

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

发布时间:2023-10-14 15:01:21 所属栏目:教程 来源:
导读:ASP.NET 的服务器控件回发是使用这一段JS代码:

代码如下:

var theForm = document.forms['form1'];

if (!theForm) {

theForm = document.form1;

}

function __doPostBack(eventTar
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() 触发的。
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章