IsPostBack解释

本文深入探讨了ASP.NET页面回发机制的原理,解释了`Page.IsPostBack`的作用,并通过实例展示了如何避免重复数据库操作和保持状态,特别是在下拉列表框数据绑定场景中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Page.IsPostBack==false表示:第一次访问页面 

Page.IsPostBack==true表示:用户点击按钮,导致提交表单时产生的页面访问。


if (!page.ispostback) 

BindGrid(); 

public void BindGrid() 




目的

1、避免重复的到数据库提取数据

2、保持状态。 
如果是绑定下拉列表框的话,就必须用这种方式绑定。 

在第一次访问的时候绑定下拉列表框,用户可以看到下拉列表框里的选项,然后作选择,比如选择了第三项,然后提交表单,这时我们希望能够得到下拉列表框选定了第三项的状态。 

如果不加上 if (!page.ispostback) 的判断的话,那么得到的选项永远都是第一项,因为每次都重新绑定,并且设置第一项被选中。 

public partial class ecsm3104 : MyBasePage //System.Web.UI.Page { public static string strEQID = string.Empty; public static string strSerialID = string.Empty; public static string strHandlerType = string.Empty; public static string strTT_Type = string.Empty; public static string strMP_Type = string.Empty; static string MailsrvName = Global.SrvName.MailServer; string EQID = string.Empty; protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { String sqlr = ""; //PTN_dbLink.sqlLink sqlLink = new PTN_dbLink.sqlLink(); string sCust_p = ""; string changeType = ""; string strHandler = ""; string sPinballS = ""; string sDutS = ""; string sSubTypeS = ""; string sPinballP = ""; string sDutP = ""; string sSubTypeP = ""; string sCKey = ""; //当前项目转机单号 string sCKey_p = "";//上一个改机项目单号 bool bNew = false; Bitmap bitmap; //sqlr = "Select ens_file.*,enj04,enj06,enj09 From ens_file INNER JOIN enj_file ON enj03 = 'FT' And enj06 = ens06 Where ens10 IN ('" + Request["NUM"].Replace("|", "','") + "') Order by ens10 "; sqlr = "Select distinct ensd01,ens_file.*,ensa04,ensa05,ensa06,ensa07,ensa08,ensa09,ensa10,ensa11,ensa12,ensa13,ensa15,ensa17, ensa18,ensa19,ensa20,ensa21,ensa22,ensa23,ensa24,ensa24,ensa25,ensa26," + "ensa27,ensa28,ensa29,ensa30,ensa31,ensa32,ensa33,ensa34,ensa35,ensa36,ensa37,ensa38,ensa39,ensa40,ensa41,ensa43,ensa44" + " From ens_file INNER JOIN ensa_file ON ensa01 = 'TESTER' And ensa02 = ens10 And ensa03 = 'FT' And ensa04 in ('HI-FIX' ,'HANDLER')" + " inner join ema_file on ema04 = ENS04" + " INNER JOIN ensd_file ON ensd02=ema07 AND ensd03=(select ROUND(convert(float,(ens24 - ens23))*24, 2) )" 解释代码功能
03-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值