手机
当前位置:查字典教程网 >编程开发 >AJAX相关 >ajax 防止用户反复提交的2种解决方案
ajax 防止用户反复提交的2种解决方案
摘要:可在服务器端加载方法:复制代码代码如下:privatevoidOnLoading(){System.Text.StringBuildersb...

可在服务器端加载方法:

复制代码 代码如下:

private void OnLoading()

{

System.Text.StringBuilder sb = new System.Text.StringBuilder();

sb.Append(" function pageLoad(){var manager = Sys.WebForms.PageRequestManager.getInstance(); ");

sb.Append(" manager.add_beginRequest(OnBeginRequest); manager.add_endRequest(OnEndRequest)} var lcPostbackElementID;");

sb.Append(" function OnBeginRequest(sender, args){ lcPostbackElementID = args.get_postBackElement().id.toLowerCase(); if (lcPostbackElementID === "btnadwords"){$get("btnAdWords").disabled = true; $get("btnAdWords").value='正在提交...';}} ");

sb.Append(" function OnEndRequest(sender, args){if (lcPostbackElementID === "btnadwords"){ $get("btnAdWords").disabled = false; $get("btnAdWords").value='确定';}} ");

ScriptManager.RegisterStartupScript(Page, Page.GetType(), "btnAdWords", sb.ToString(), true);

}

也可直接写在页面脚本里:

复制代码 代码如下:

<script>

function pageLoad()

{

var manager = Sys.WebForms.PageRequestManager.getInstance();

manager.add_beginRequest(OnBeginRequest);

manager.add_endRequest(OnEndRequest)

}

var lcPostbackElementID;

function OnBeginRequest(sender, args)

{

lcPostbackElementID = args.get_postBackElement().id.toLowerCase();

if (lcPostbackElementID === 'btnadwords')

{

$get('btnAdWords').disabled = true;

$get('btnAdWords').value='正在提交...';

}

}

function OnEndRequest(sender, args)

{

if (lcPostbackElementID === "btnadwords")

{

$get('btnAdWords').disabled = false;

$get('btnAdWords').value='确定';

}

}

< /script>

更多内容请参考:http://msdn.microsoft.com/zh-cn/magazine/cc163319.aspx

【ajax 防止用户反复提交的2种解决方案】相关文章:

防止重复发送Ajax请求的解决方案

ajax后退解决方案

IE9版本以下ajax 跨域问题可行解决方法

ajax session过期问题的几个解决方案

AJAX提交与FORM提交的区别说明

jQuery Ajax方式上传文件的方法

ajax传递多个参数的实现代码

ajax传送参数含有特殊字符的快速解决方法

ajax 检测用户名是否被占用

AJAX中文乱码解决新方法分享

精品推荐
分类导航