关闭

防止重复提交的脚本。

366人阅读 评论(0) 收藏 举报

把这个作为 <-script src=.....js-><-/script-> 的形式Render到每个页面中就可以了。|
如果有PageBase,则在Init的时候用RegisterClientScriptBlock放上去更好。
因为客户没有抱怨过,所以也没有改进过。


function _doPostBack(){};
if(typeof("__doPostBack")=="function")
{
    _doPostBack=__doPostBack;
    __doPostBack=_doPostBackNew;
}

document.attachEvent("onmousemove",_onmousemove);
var _isPosting=false;
var _divMask=null;

function _onmousemove()
{
    if(_divMask)
    with(_divMask.runtimeStyle)
    {
        left=event.clientX+document.body.scrollLeft-4;
        top=event.clientY+document.body.scrollTop-4;
    }
}


function _makeMask()
{
    var div=document.createElement("DIV");
    with(div.runtimeStyle)
    {
        position="absolute";
        zIndex=999999;
        fontSize="1px";
        left=event.clientX+document.body.scrollLeft-4;
        top=event.clientY+document.body.scrollTop-4;
        width="8px";
        height="8px";
        cursor="wait";
       
        backgroundColor="gray";
        filter="alpha(opacity=10)";
    }
    try
    {
        document.body.insertAdjacentElement("BeforeEnd",div);
        div.onblur=new Function("this.focus()");
        div.focus();
    }
    catch(x){}
   
    if(_divMask)_divMask.removeNode(true);
    _divMask=div;
}

function _doPostBackNew(sender,args)
{
    if(_isPosting)
        return event.returnValue=!(event.cancelBubble=true);

    status="正在更新页面...";
    _doPostBack(sender,args);       
    _isPosting=true;
    _makeMask();
}

function _onformsubmit()
{
    if(_isPosting)
        return event.returnValue=!(event.cancelBubble=true);

    _isPosting=true;
    _makeMask();
}
new function _attachForms()
{
    with(new Enumerator(document.forms))
    for(;!atEnd();moveNext())
    {
        item().attachEvent("onsubmit",_onformsubmit);
        var div=document.createElement("div");
        div.runtimeStyle.width="0px";
        div.runtimeStyle.hight="0px";
        div.runtimeStyle.overflow="hidden";
        div.runtimeStyle.position="absolute";
        item(0).insertAdjacentElement("afterbegin",div);
        div.innerHTML="<INPUT TYPE=Submit name='webformpatchsubmitelement' onclick='return event.returnValue=false' id='webformpatchsubmitelement' value='webformpatchsubmitelement'/>";
    }
}

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:106112次
    • 积分:2291
    • 等级:
    • 排名:第16966名
    • 原创:111篇
    • 转载:3篇
    • 译文:0篇
    • 评论:7条
    文章分类