电脑爱好者,提供IT资讯信息及各类编程知识文章介绍,欢迎大家来本站学习电脑知识。 最近更新 | 联系我们 RSS订阅本站最新文章
电脑爱好者
站内搜索: 
当前位置:首页>> asp.net综合>>ASP.NET Button控件UseSubmitBehavior属性对回发的影响 .:

ASP.NET Button控件UseSubmitBehavior属性对回发的影响 .

来源:Qiyeye的专栏 | 2013-4-27 | (有2611人读过)

对于Button控件的UseSubmitBehavior属性以前一直存在一些理解上的误区,特别是它和OnClientClick事件一起使用时。 

下面就对Button控件的UseSubmitBehavior属性和OnClientClick事件的使用做一个详细的说明: 

首先说一下UseSubmitBehavior属性的定义: 

UseSubmitBehavior为true时(默认),Button控件(类)会被呈现为 <input type="submit">标签,利用浏览器的提交机制进行回发。 

UseSubmitBehavior为false时,Button控件(类)会被呈现为 <input type="button">标签,这种情况下,该Button控件仍为回发按钮,该控件的onclick客户端事件处理程序会绑定到一段由ASP.NET回发机制提供的JavaScript代码上(__doPostBack函数),LinkButton和ImageButton控件也同样如此。即Button控件被呈现为 

<input type="button"  onclick="__doPostBack(Button, ’’)"  id="Button" /> 

__doPostBack函数如下: 

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(); 
    } 


示例代码如下: 

  <script type="text/javascript" language="javascript"> 
        function SubmitButton_Client_True_click() { 
            alert("SubmitButton_Client_True client click!"); 
            return true; 
        } 
        function SubmitButton_Client_False_click() { 
            alert("SubmitButton_Client_False client click!"); 
            return false; 
        } 
        function GeneralButton_Client_True_click() { 
            alert("GeneralButton_Client_True client click!"); 
            return true; 
        } 
        function GeneralButton_Client_False_click() { 
            alert("GeneralButton_Client_False client click!"); 
            return false; 
        } 
    </script> 

<asp:Button ID="SubmitButton_Client_True" runat="server" Text="SubmitButton_Client_True" 
            UseSubmitBehavior="true" OnClientClick="return SubmitButton_Client_True_click();" 
            OnClick="SubmitButton_Click" /> 
        &nbsp;&nbsp; 
        <asp:Button ID="SubmitButton_Client_True2" runat="server" Text="SubmitButton_Client_True2" 
            UseSubmitBehavior="true" OnClientClick="SubmitButton_Client_True_click();" 
            OnClick="SubmitButton_Click" /> 
        &nbsp;&nbsp; 
        <asp:Button ID="SubmitButton_Client_False" runat="server" Text="SubmitButton_Client_False" 
            UseSubmitBehavior="true" OnClientClick="return SubmitButton_Client_False_click();" 
            OnClick="SubmitButton_Click" /> 
        &nbsp;&nbsp; 
        <asp:Button ID="SubmitButton_Client_False2" runat="server" Text="SubmitButton_Client_False2" 
            UseSubmitBehavior="true" OnClientClick="SubmitButton_Client_False_click();" OnClick="SubmitButton_Click" /> 
        &nbsp;&nbsp; 
        <asp:Button ID="GeneralButton_Client_True" runat="server" Text="GeneralButton_Client_True" 
            UseSubmitBehavior="false" OnClientClick="return  GeneralButton_Client_True_click();" 
            OnClick="GeneralButtonClick" /> 
        &nbsp;&nbsp; 
        <asp:Button ID="GeneralButton_Client_True2" runat="server" Text="GeneralButton_Client_True2" 
            UseSubmitBehavior="false" OnClientClick=" GeneralButton_Client_True_click();" 
            OnClick="GeneralButtonClick" /> 
        &nbsp;&nbsp; 
        <asp:Button ID="GeneralButton_Client_False" runat="server" Text="GeneralButton_Client_False" 
            UseSubmitBehavior="false" OnClientClick="return  GeneralButton_Client_False_click();" 
            OnClick="GeneralButtonClick" /> 
        &nbsp;&nbsp; 
        <asp:Button ID="GeneralButton_Client_False2" runat="server" Text="GeneralButton_Client_False2" 
            UseSubmitBehavior="false" OnClientClick=" GeneralButton_Client_False_click();" 
            OnClick="GeneralButtonClick" /> 

页面被呈现的HTML如下: 

<input type="submit" name="SubmitButton_Client_True" value="SubmitButton_Client_True" onclick="return SubmitButton_Client_True_click();" id="SubmitButton_Client_True" /> 
        &nbsp;&nbsp; 
        <input type="submit" name="SubmitButton_Client_True2" value="SubmitButton_Client_True2" onclick="SubmitButton_Client_True_click();" id="SubmitButton_Client_True2" /> 
        &nbsp;&nbsp; 
        <input type="submit" name="SubmitButton_Client_False" value="SubmitButton_Client_False" onclick="return SubmitButton_Client_False_click();" id="SubmitButton_Client_False" /> 
        &nbsp;&nbsp; 
        <input type="submit" name="SubmitButton_Client_False2" value="SubmitButton_Client_False2" onclick="SubmitButton_Client_False_click();" id="SubmitButton_Client_False2" /> 
        &nbsp;&nbsp; 
        <input type="button" name="GeneralButton_Client_True" value="GeneralButton_Client_True" onclick="return  GeneralButton_Client_True_click();__doPostBack(’GeneralButton_Client_True’,’’)" id="GeneralButton_Client_True" /> 
        &nbsp;&nbsp; 
        <input type="button" name="GeneralButton_Client_True2" value="GeneralButton_Client_True2" onclick=" GeneralButton_Client_True_click();__doPostBack(’GeneralButton_Client_True2’,’’)" id="GeneralButton_Client_True2" /> 
        &nbsp;&nbsp; 
        <input type="button" name="GeneralButton_Client_False" value="GeneralButton_Client_False" onclick="return  GeneralButton_Client_False_click();__doPostBack(’GeneralButton_Client_False’,’’)" id="GeneralButton_Client_False" /> 
        &nbsp;&nbsp; 
        <input type="button" name="GeneralButton_Client_False2" value="GeneralButton_Client_False2" onclick=" GeneralButton_Client_False_click();__doPostBack(’GeneralButton_Client_False2’,’’)" id="GeneralButton_Client_False2" /> 


逐个单击之后不难发现其中当Button控件OnClientClick="return  GeneralButton_Client_False_click();" 中是否使用return对回发有直接影响。 

1. 当UseSubmitBehavior为true时 

a. 若使用return,只有客户端JS函数返回true时,才会回发。 

b. 若不使用return, 不管客户端脚本运行结果如何,始终会回发。 

2. 当UseSubmitBehavior为false时 

a. 若使用return,不管客户端脚本运行结果如何,始终都不会回发。(因为__doPostBack函数在return语句之后,永远不会执行) 
b. 若不使用return, 不管客户端脚本运行结果如何,始终会回发。 
asp.net综合热门文章排行
网站赞助商
购买此位置

 

关于我们 | 网站地图 | 文档一览 | 友情链接| 联系我们

Copyright © 2003-2024 电脑爱好者 版权所有 备案号:鲁ICP备09059398号