1:
OnClick与OnClientClick
OnClientClick是客户端事件处理方法,一般采用JavaScript来进行处理,也就是直接在IE端运行,一点击就运行
OnClick是服务器端事件处理方法,在服务器端也就是IIS中运行,点击后,先执行postback,再运行
OnClientClick常用来做一些客户端的检测。当然也可以放在服务器端检测,但是需要与服务器进行交互,消耗资源,而且用户体验也不好。
当一个控件上同时有OnClick和OnClientClick时,OnClientClick先于OnClick执行
正确的写法应该是:
<asp:Button ID="btnSave" runat="server" Text="Save" OnClick="btnSave_Click" OnClientClick="return saveFunc();" />
saveFunc对数据进行验证,当验证通过返回true时,执行服务器端方法进行保存,验证不通过返回false,服务器端的保存方法就不会执行。
错误的写法:
代码<!--无论验证是否通过,都会执行服务器端方法,不能达到验证的目的--><asp:Button ID="btnSave" runat="server" Text="Save" OnClick="btnSave_Click" OnClientClick="saveFunc();" />
<!--无论验证结果如何都返回false,服务器端方法永远不会执行--><asp:Button ID="btnSave" runat="server" Text="Save" OnClick="btnSave_Click" OnClientClick="saveFunc(); return false;" />
<script type="text/javascript">
function delcfm() {if (!confirm("确认要删除?")) {window.event.returnValue = false;}}
</script>
<asp:LinkButton ID="lbnDeletess" runat="server" CausesValidation="False" Text="Delete"OnClientClick="delcfm();" OnClick="lbnDelete_Click" ></asp:LinkButton>
select * from h_tel_record where trunc(lm_time) BETWEEN TO_DATE('2016/1/1','yyyy/mm/dd') and to_date('2016/1/6','yyyy/mm/dd') order by lm_time
select count(*) from h_tel_recorddelete from h_tel_record where trunc(lm_time) BETWEEN TO_DATE('2016/1/1','yyyy/mm/dd') and to_date('2016/1/6','yyyy/mm/dd') order by lm_time
遇到一个问题:1:Request.QueryString(“id”)2:select from database3:input .aspx textbox
4:edit .aspx textbox
5:回传数据出现问题
6:解决之道 了解IsPostBack 机制
7:问题 解决
1、IsPostBack介绍Page.IsPostBack是一个标志:当前请求是否第一次打开。 调用方法为:Page.IsPostBack或者IsPostBack或者this.IsPostBack或者this.Page.IsPostBack,它们都等价。1)当通过IE的地址栏等方式打开一个URL时是第一次打开, 当通过页面的提交按钮或能引起提交的按钮以POST的方式提交的服务器时,页面就不再是第一次打开了。(每点击一次按钮,都是一次加载)2)IsPostBack只有在第一次打开的时候是false,其它时候都是true3).Net判断一个Page是否第一次打开的方法:Request.Form.Count>04)每次页面Load的时候,根据需要把每次都要加载的代码放在IsPostBack中,只需要加载一次的代码放在if(!IsPostBack)中。5)每次用户回传服务器任何信息的时候,都会引发isPostBack属性用来判断此用户是
否曾经做过登陆或者其他事件6 if(!IsPostBack){Response.Write("第一次提交!");}if(IsPostBack){Response.Write("按按钮!");}2 IsPostBack结论本人对.Net的源代码中相关的处理进行的分析得到如下的结论:结论① 对于使用Server.Transfer进行迁移时迁移到的页面其IsPostBack=false。结论② Post方式如果Request中没有请求值,即Request.Form =null则IsPostBack=false;Get方式如果Request中没有请求值,即Request.QueryString =null则IsPostBack=false。结论③ 如果QueryString或Form虽然有请求值,但是QueryString或Form中的Key没有“__VIEWSTATE”和“__EVENTTARGET”和“__VIEWSTATEFIELDCOUNT”,并且没有键为“null”,值以“__VIEWSTATE”开头并且也没有值为“__EVENTTARGET”的键值对,则IsPostBack=false。结论④ 使用Response.Redirect方式向自画面迁移时,此时IsPostBack=false。结论⑤ 发生跨页提交(CrossPagePostBack),当访问PreviousPage属性的时候,对于源PageIsPostBack=true。结论⑥ 发生跨页提交(CrossPagePostBack)时目标页面是IsPostBack=false结论⑦ 使用Server.Execute迁移到的页面其IsPostBack=false。结论⑧ 在Page运行期间其对应的DLL被更新了并且Page的树结构发生过变化,这种情况下请求时IsPostBack=false。可以这样来理解这些结论:一般情况判断Request中如果没有请求值则IsPostBack=false。如果有请求值但是不包括“__VIEWSTATE”等一些特殊的键或值,则IsPostBack=false(每次请求后.Net框架会将一些特殊的隐藏域
“__VIEWSTATE”等返回给客户端)。还有一些特殊的情形是上面的规则不能正确判断的需要特殊处理的,这些情形包括Server.Transfer,Response.Redirect,CrossPagePostBack,Server.Execute,发生了页面元素变化及重新编译。
onclick onclientclick postback 机制
最新推荐文章于 2019-07-30 05:28:01 发布