IsPostBack具体功能?

作者&投稿:锻航 (若有异议请与网页底部的电邮联系)
ASP.NET中的IsPostBack是什么意思?怎么用?~

IsPostBack是Page类有一个bool类型的属性,用来判断针对当前Form的请求是第一次还是非第一次请求。当IsPostBack=true时表示非第一次请求,我们称为PostBack,当IsPostBack=false时表示第一次请求。
对于我们自己使用WebForm进行开发时,经常会在Page_Load中对IsPostBack进行判断,因为第一次请求的时候会执行Page_Load,在非第一次请求的时候也会执行Page_Load。为什么对同一个Form有多次请求呢?asp.net中引入了服务器端事件,支持服务器端事件的控件,会发出对当前Form的请求,这样在很多情形下我们就需要区别是否是对这个Form的第一次请求
所以在程序程序一般都有
Page_Load事件中就有了
if(!IsPostBack)
{
//第一次请求时加载,注意前面的“!”

}

你第一次打开一个aspx页面,就是首次加载,然后你点击了页面中的某个按钮,或者其他控件,这个动作如果引起了页面的刷新,就是PostBack了,IsPostBack是个逻辑值,用于判断该次页面的刷新(加载)是客户端首次加载页面,还是客户端做出了什么请求的动作,为了响应此动作而再次加载页面。
一般都在页面首次加载时完成一些控件的初始化,数据的绑定之类的,这些事情不放在那个If里面的话,你会发现很多莫名其妙的错误。

1 IsPostBack介绍

IsPostBack是Page类有一个bool类型的属性,用来判断针对当前Form的请求是第一次还是非第一次请求。当IsPostBack=true时表示非第一次

请求,我们称为PostBack,当IsPostBack=false时表示第一次请求。在asp.net框架内部有很多的场景需要判断IsPostBack,比如

LoadAllState等操作就需要在PostBack的时候进行。对于我们自己使用WebForm进行开发时,经常会在Page_Load中对IsPostBack进行判断,因

为第一次请求的时候会执行Page_Load,在非第一次请求的时候也会执行Page_Load。为什么对同一个Form有多次请求呢?asp.net中引入了服务

器端事件,支持服务器端事件的控件,会发出对当前Form的请求,这样在很多情形下我们就需要区别是否是对这个Form的第一次请求。

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属性的时候,对于源Page,IsPostBack=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,发

生了页面元素变化及重新编译。

一般来说记住上面的结论就可以,如果您有兴趣,或者怀疑请继续看下面的IsPostBack推论过程。

3 IsPostBack推论过程

下面是根据.Net框架中的源代码,来分析IsPostBack是如何判断出来的。对于这些结论的推断本人做了相关的试验来证明推论的正确性,由于

篇幅的原因没有将这些试验代码体现出来。另外不可能将全部的.Net框架的代码都体现出来,只是将相关的代码片段列出,说明推断的依据。

另外由于本人水平有限对.Net框架的代码理解还存在的不足的地方,请发现后进行指正,谢谢。

publicbool IsPostBack

{

get

{

if (this._requestValueCollection == null)

{

return false;

}

if (this._isCrossPagePostBack)

{

return true;

}

if (this_pageFlags[8])

{

return false;

}

return (

(

(this.Context.ServerExecuteDepth <= 0) ||

((this.Context.Handler != null) &&

(base.GetType() == this.Context.Handler.GetType()))

) && !this._fPageLayoutChanged

);

}

}

我们将每一个if判断作为一个小节,作如下的分析。

3.1 this._requestValueCollection == null

if (this._requestValueCollection == null)

{

return false;

}

可以看出_requestValueCollection等于null时IsPostBack就等于false。

在Page.ProcessRequestMain(bool, bool)中有如下的代码:

if (this.PageAdapter != null)

{

this._requestValueCollection = this.PageAdapter.DeterminePostBackMode();

}

else

{

this._requestValueCollection = this.DeterminePostBackMode();

}

PageAdapter.DeterminePostBackMode最终还是调用了Page.DeterminePostBackMode,下面我们看Page.DeterminePostBackMode如何实现。

protected internal virtual NameValueCollection DeterminePostBackMode()

{

if (this.Context.Request == null)

{

return null;

}

if (this.Context.PreventPostback)

{

return null;

}

NameValueCollection collectionBasedOnMethod = this.GetCollectionBasedOnMethod(false);

if (collectionBasedOnMethod == null)

{

return null;

}

bool flag = false;

string[] values = collectionBasedOnMethod.GetValues((string) null);

if (values != null)

{

int length = values.Length;

for (int i = 0; i < length; i++)

{

if (values[i].StartsWith("__VIEWSTATE", StringComparison.Ordinal) ||

(values[i] == "__EVENTTARGET"))

{

flag = true;

break;

}

}

}

if (((collectionBasedOnMethod["__VIEWSTATE"] == null) && (collectionBasedOnMethod["__VIEWSTATEFIELDCOUNT"] == null)) &&

((collectionBasedOnMethod["__EVENTTARGET"] == null) && !flag))

{

return null;

}

if (this.Request.QueryStringText.IndexOf(

HttpResponse.RedirectQueryStringAssignment, StringComparison.Ordinal) != -1)

{

collectionBasedOnMethod = null;

}

return collectionBasedOnMethod;

}

这个函数中返回null就意味者IsPostBack=false,将上面函数中每个返回为null的地方作如下的分析。

3.1.1 this.Context.Request == null

if (this.Context.Request == null) { return null; }this.Context.Request == null应该只有在异常的情况下会发生,

正常情况下会在HttpRuntime.ProcessRequestInternal中创建HttpContext及HttpRequest对象。

3.1.2 this.Context.PreventPostback

if (this.Context.PreventPostback) { return null; }在HttpServerUtility.Transfer中会使用PreventPostback,其代

码如下:

public void Transfer(string path)

{

bool preventPostback = this._context.PreventPostback;

this._context.PreventPostback = true;

this.Transfer(path, true);

this._context.PreventPostback = preventPostback;

}

在调用Server.Transfer进行画面迁移时设置Context.PreventPostback=ture。此处得出结论①:对于使用Server.Transfer进行迁移时迁移到

的页面其IsPostBack=false。

3.1.3 collectionBasedOnMethod == null

NameValueCollection collectionBasedOnMethod = this.GetCollectionBasedOnMethod(false);

if (collectionBasedOnMethod == null)

{

return null;

}

调用了Page.GetCollectionBasedOnMethod后其返回值进行判断。如果其返回值为null则IsPostBack为false。

Page.GetCollectionBasedOnMethod的定义如下:

internal NameValueCollection GetCollectionBasedOnMethod(bool dontReturnNull)

{

if (this._request.HttpVerb == HttpVerb.POST)

{

if (!dontReturnNull && !this._request.HasForm)

{

return null;

}

return this._request.Form;

}

if (!dontReturnNull && !this._request.HasQueryString)

{

return null;

}

return this._request.QueryString;

}

从上面的代码可以看出返回值为null的情形是_request.HasForm=null或_request.HasQueryString=null。此处得出结论②:Post方式如果

Request中没有请求值,即Request.Form =null则IsPostBack=false;Get方式如果Request中没有请求值,即Request.QueryString =null则

IsPostBack=false。

3.1.4 ((collectionBasedOnMethod["__VIEWSTATE"] == null) && (collectionBasedOnMethod["__VIEWSTATEFIELDCOUNT"] == null)) &&

((collectionBasedOnMethod["__EVENTTARGET"] == null) && !flag)

bool flag = false;

string[] values = collectionBasedOnMethod.GetValues((string) null);

if (values != null)

{

int length = values.Length;

for (int i = 0; i < length; i++)

{

if (values[i].StartsWith("__VIEWSTATE", StringComparison.Ordinal) ||

(values[i] == "__EVENTTARGET"))

{

flag = true;

break;

}

}

}

上面这段代码的意思是判断请求的键值对中是否存在没有键,其值以“__VIEWSTATE”开头或者其值为“__EVENTTARGET”。例如如下的Get请求

方式会使得flag=true。

…/defalt.aspx?__VIEWSTATE

…/defalt.aspx?__EVENTTARGET

对于Get方式“?__VIEWSTATE=”会将__VIEWSTATE作为请求的键,其值为“”,但是“?__VIEWSTATE”会认为其键为“null”,其值为

“__VIEWSTATE”

if (

((collectionBasedOnMethod["__VIEWSTATE"] == null) && (collectionBasedOnMethod["__VIEWSTATEFIELDCOUNT"] == null)) &&

((collectionBasedOnMethod["__EVENTTARGET"] == null) && !flag))

{

return null;

}

如上的条件意味着请求的键中同时没有“__VIEWSTATE”,“__EVENTTARGET”,“__VIEWSTATEFIELDCOUNT”,并且flag为false则返回null。

flag为false意味着没有键为“null”值以“__VIEWSTATE”开头并且也没有值为“__EVENTTARGET”的键值对。

此处得出结论③如果QueryString或Form虽然有请求值,但是QueryString或Form中的Key没有“__VIEWSTATE”和“__EVENTTARGET”和

“__VIEWSTATEFIELDCOUNT”,并且没有键为“null”值以“__VIEWSTATE”开头并且也没有值为“__EVENTTARGET”的键值对,则IsPostBack=

false。

3.1.5 this.Request.QueryStringText.IndexOf(HttpResponse.RedirectQueryStringAssignment, StringComparison.Ordinal) != -1

if (this.Request.QueryStringText.IndexOf(HttpResponse.RedirectQueryStringAssignment, StringComparison.Ordinal) != -1)

{

collectionBasedOnMethod = null;

}

HttpResponse.RedirectQueryStringAssignment的值为“__redir=1”,上面的代码的意思是如果QueryStringText中包括包括“__redir=1”

则返回null。在HttpRequest.Redirect中会判断如果IsPostBack为true,并且URL中不包含有“__redir=1”时,会给URL中增加“__redir=1

”。一般情况下我们使用request.Redirect迁移到的页面都应该是IsPostBack=false,有一种特殊的情形是使用request.Redirect迁移到当前

页,此时IsPostBack为true。此种情况发生时在request.Redirect中给URL中增加“__redir=1”。执行到page. ProcessRequestMain时会重新

将IsPostBack判断为fales。

此处得出结论④使用Response.Redirect方式向自画面迁移时,此时IsPostBack=false。

此时大家可能会有疑问为什么使用Response.Redirect方式向自画面迁移时要特殊处理,使用Response.Redirect向其他画面迁移为什么不要。

使用Response.Redirect向其他画面迁移时Response.Form=null,Response.QueryString=null,所以可以判断是IsPostBack=false。但是使用

Response.Redirect方式向自画面迁移时Response.QueryString<>null,所以要特殊判断。

3.2 this._isCrossPagePostBack

if (this._isCrossPagePostBack)

{

return true;

}

在Page的PreviousPage属性中会对_isCrossPagePostBack进行设置,具体代码如下:

public Page PreviousPage

{

get

{



ITypedWebObjectFactory vPathBuildResult = (ITypedWebObjectFactory) BuildManager.GetVPathBuildResult(this.Context,

this._previousPagePath);

if (typeof(Page).IsAssignableFrom(vPathBuildResult.InstantiatedType))

{

this._previousPage = (Page) vPathBuildResult.CreateInstance();

this._previousPage._isCrossPagePostBack = true;

this.Server.Execute(this._previousPage, TextWriter.Null, true, false);

}

}

return this._previousPage;

}

}

在发生跨页面提交的时候,当访问PreviousPage属性的时候源Page的IsCrossPagePostBack会被设置true。此处得出结论⑤发生跨页提交

(CrossPagePostBack),当访问PreviousPage属性的时候,对于源Page,IsPostBack=true。

3.3 this._pageFlags[8]

if (this._pageFlags[8])

{

return false;

}

在Page. ProcessRequestMain中有如下的代码片断对_pageFlags[8]进行赋值。

else if (!this.IsCrossPagePostBack)

{

VirtualPath path = null;

if (this._requestValueCollection["__PREVIOUSPAGE"] != null)

{

try

{

path = VirtualPath.CreateNonRelativeAllowNull(

DecryptString(this._requestValueCollection["__PREVIOUSPAGE"]));

}

catch (CryptographicException)

{

this._pageFlags[8] = true;

}

if ((path != null) && (path != this.Request.CurrentExecutionFilePathObject))

{

this._pageFlags[8] = true;

this._previousPagePath = path;

}

}

}

解密发生异常时_pageFlags[8]为true这种异常发生的可能性比较小我们忽略,重点看另外一种情形,将这种情形的所有条件结合起来就是

IsCrossPagePostBack=false && _requestValueCollection["__PREVIOUSPAGE"] != null && path != null && (path !=

this.Request.CurrentExecutionFilePathObject)。发生跨页提交时对于目标页面IsCrossPagePostBack=false,此时源页面

的"__PREVIOUSPAGE"等信息会提交给目标页面,所以_requestValueCollection["__PREVIOUSPAGE"] != null。此时当前请求的

CurrentExecutionFilePathObject是根据目标页的路径生成的,与使用_requestValueCollection["__PREVIOUSPAGE"]生成的path对象不同。

此处得出结论⑥发生跨页提交(CrossPagePostBack)时目标页面是IsPostBack=false。为什么需要对CrossPagePostBack的目标页面做这样的

处理呢?发生CrossPagePostBack时,会将源页面的信息提交给目标页面此时Request.Form!=null,而且包括__VIEWSTATE等键按照其他的规

则会判断为IsPostBack=true,所以需要对CrossPagePostBack的目标页面做特殊的判断。

3.4 (this.Context.ServerExecuteDepth <= 0) || ((this.Context.Handler != null) && (base.GetType() ==

this.Context.Handler.GetType()))

在HttpServerUtility中有如下的代码对Context. ServerExecuteDepth进行了操作。

public void Execute(string path, TextWriter writer, bool preserveForm)

{



try

{

this._context.ServerExecuteDepth++;

handler = this._context.ApplicationInstance.MapHttpHandler(this._context, request.RequestType, path3, filename,

useAppConfig);

}

finally

{

this._context.ServerExecuteDepth--;

}



}

在HttpServerUtility.ExecuteInternal中也有一处对Context.ServerExecuteDepth类似的操作。HttpServerUtility.Execute会调用

HttpServerUtility.ExecuteInternal。从此可以看出Context.ServerExecuteDepth是表示Server.Execute中的执行深度。在调用

Server.Execute时Context.ServerExecuteDepth>0。另外调用Server.Execute后Context.Handle中存储的还是原来的页对象,也就是说

base.GetType()!= this.Context.Handler.GetType()。这样对于Server.Execute来说this.Context.ServerExecuteDepth <= 0) ||

((this.Context.Handler != null)这个条件为false。此处得出结论⑦使用Server.Execute迁移到的页面其IsPostBack=false。此处我们会有

疑问,为什么需要对Server.Execute进行特殊的判断呢?理由是使用Server.Execute时会将源Page中的隐含域提交,此时Request.Form!=null

,而且包括__VIEWSTATE等键按照其他的规则会判断为IsPostBack=true。

3.5 this._fPageLayoutChanged

fPageLayoutChanged从这个变量的字面意思来看是Page的Layout发生了变化。

在Page.LaodAllState中代码片断如下:

private void LoadAllState()

{



string s = (string) second.First;

int num = int.Parse(s, NumberFormatInfo.InvariantInfo);

this._fPageLayoutChanged = num != this.GetTypeHashCode();



}

其意思是现在得到的HashCode和存储在ViewState中的HashCode不一致时fPageLayoutChanged=true。GetTypeHashCode()会返回一个HashCode

,而且这个方法是对aspx进行编译的时候产生的,只有在页面上的元素发生了变化的时候其返回的值会发生变化。此处得出结论⑧在Page运行

期间其对应的DLL被更新了并且Page的树结构发生过变化,这种情况下请求时IsPostBack=false。

  1、IsPostBack用来做一些初始化,如DROPDOWN的初始化,ViewState的初始值等,一般这个函数里面的内容是指第一次打开这个页面的时候要做的事.
  2、在加载页面后(首次加载页面IsPostBack的值为false),如果我们要在这个页面上点击按钮或其他东西提交时候,会重新执行Page_Load()函数里面的东西,但是不执行if(!IsPostBack){}里的东西,因为这时候IsPostBack的值是true.

IsPostBack是判断页面是否回传,若IsPostBack为TRUE的话那就是回传,要是False为首次加载,IsPostBack默认为FALSE


静态评测新款奥迪A3:该坐等新车,还是抄底现款?
说来也巧,笔者在今年广州车展上静态体验了全新奥迪A3,加长之后的A3L保留运动化外观的同时,加大了后排空间,在BBA入门级车型中的竞争力得到了提升。根据笔者在现场体验后的结果来看,对于新车,我劝大家购买两厢版本(也就是Sportback),下面我就跟大家分享一下缘由,重点也讲一下到底该抄底现款,还是...

现在奥迪A1多少钱?——详解奥迪A1的价格与配置
一、奥迪A1的售价区间 目前,奥迪A1的售价区间主要集中在16.59万元~23.79万元之间。其中,最基础的奥迪A1 Sportback 25 TFSI 手动动力标准型车型售价约为16.59万元,而全系最高配置的奥迪A1 Sportback 40 TFSI Quattro S line运动型售价约为23.79万元。二、不同配置奥迪A1的售价分析 1.奥迪A1 ...

来吧,奥迪Q5L和Q5L Sportback有何不同,该买谁?
奥迪在今年北京车展上发布了 奥迪Q5L Sportback,?这也是BBA品牌下首辆国产的SUV轿跑车型。在奥迪Q5L这台中国特供车销量极佳的情况下,奥迪推出Q5L轿跑,从很大程度上来看是一件水到渠成的事情?否则首先被“Sportback”的也应该是标准版的Q5。要说Q5L和Q5L轿跑这两台车有何不同,倒不如说说他们什么...

解开优雅的“密码”,试驾奥迪Q5L Sportback
这些年随着SUV市场的持续升温,让轿跑SUV这一昔日小众车型,如今也开始受到更多消费者关注,各大厂商陆续入局,从自主车企到普通合资,再到豪华品牌……我们都能看到这类车型的身影,为了与老对手宝马X4和奔驰GLC Coupe抗衡,奥迪继Q3 Sportback之后,于去年又在现款Q5L的基础上推出了Q5L Sportback版本,...

奥迪Q5L Sportback,外观豪华个性,底盘扎实
汽车走进生活,选最适合自己的车。哈喽,大家好,我是红涛说车。国内消费者对豪华品牌中型SUV很是喜爱,其中奥迪Q5L是这个级别中的热门选手,取得了很好的销量成绩,而今天红涛要说的主角,是基于奥迪Q5L衍生出来了一款跨界SUV,它的名字叫做奥迪Q5L Sportback,来看看是不是你喜欢的那台座驾。车型:...

年轻人的个性选择 到店实拍解读奥迪Q3 sportback
近日,我们对 奥迪Q3 sportback车型进行了实车拍摄,这样一款极具个性的轿跑SUV来看一看是不是你的菜。外观方面无疑是奥迪Q3 sportback最大的亮点,有人说奥迪Q3 sportback是缩小版的奥迪Q8,我并不是完全赞同,尤其是奥迪Q3 sportback溜背的程度更为舒展和夸张。首先来看奥迪Q3 sportback的前部设计,这...

奥迪Q5Sportback是奥迪首次率先在中国推出的全新车型
今天给大家介绍的主角是一汽-大众奥迪Q5LSportback,下面让我们一起来了解一下。外观上,前脸采用奥迪最新家族式设计语言,大尺寸多边形格栅内部填充全新3D立体蜂窝状装饰,中网也为蜂窝网状填充。另外,品牌LOGO以及车身饰板均进行了亮黑色处理。整体来说,轿跑版车型在前脸方面的造型与奥迪Q5L普通版车型差别...

奥迪Q5轿跑与Q5L,到底该买谁?
在之前的北京车展的奥迪展台上, 奥迪Q5L Sportback亮相了,作为奥迪家族第二款Sportback SUV,奥迪Q5L Sportback比奥迪Q3 Sportback带来了更大的空间和更加精致的外观。现在的轿跑型SUV真的是越来越多了,光BBA三家中的轿跑型SUV就很多,比如宝马的X4、X6,奔驰的GLC Coupe、GLE Coupe,国产的轿跑型SUV...

目前上市的奥迪Q5L Sportback该如何选择?
众所周知,奥迪当下Q3有轿跑版本的Q3 Sportback车型,Q7也有轿跑版本的Q8,那么夹在中间的 奥迪Q5L当下也出了一款Q5L的轿跑版本,并且也相继上市了!目前这款车型的指导价从42.68万一直到49.99万,当然分为2.0T高功率与低功率车型,今天我们就一起来看看这些车型,最值得入手哪一款!先来看低功率...

奥迪Q5 Sportback发布,这款轿跑SUV够野吗?
从今年三月首次曝光以来,新款奥迪Q5 Sportback就一直备受关注。近日,这款中型SUV终于正式发布,奥迪称新款Q5的车身整体优雅且不失动感,因为这是Q5首次推出Sportback车型。本次推出的奥迪Q5 Sportback共有五款细分车型,包括Sport、S line、Vorsprung和Edition One。这些车型又可以选择TDI、TFSI、插电式混合...

随州市18724581105: IsPostBack具体功能? -
栾虎亚胺: 1、IsPostBack用来做一些初始化,如DROPDOWN的初始化,ViewState的初始值等,一般这个函数里面的内容是指第一次打开这个页面的时候要做的事.2、在加载页面后(首次加载页面IsPostBack的值为false),如果我们要在这个页面上点击按钮或其他东西提交时候,会重新执行Page_Load()函数里面的东西,但是不执行if(!IsPostBack){}里的东西,因为这时候IsPostBack的值是true.

随州市18724581105: 谁鞥告诉我IsPostBack的具体功能是啥? -
栾虎亚胺: IsPostBack是Page类有一个bool类型的属性,用来判断针对当前Form的请求是第一次还是非第一次请求.当IsPostBack=true时表示非第一次 请求,我们称为PostBack,当IsPostBack=false时表示第一次请求.在asp.net框架内部有很多的场景需...

随州市18724581105: C#中的ispostback是什么,能讲详细点它的功能和使用 -
栾虎亚胺: 就是判断当前页面是不是你提交过后再次由服务器回传过来的 你直接在网址里输入一个页面地址访问页面的时候 这时在服务器端创建的页面对象的IsPostBack属性为false 在你对这个页面进行提交的时候 会把你页面控件里的一些值啊什么的东西...

随州市18724581105: if (!page.IsPostBack )具体作用是? -
栾虎亚胺: Page.IsPostBack 是用来检查目前网页是否为第一次加载,当使用者第一次浏览这个网页时Page.IsPostBack 会传回False,不是第一次浏览这个网页时就传回True;所以当我们在Page_Load 事件中就可以使用这个属性来避免做一些重复的动作.

随州市18724581105: IsPostBack具体功能?
栾虎亚胺: IsPostBack是用来判断是不是由于当前页面上的控件导致的页面重新加载. 你按f5刷新当然结果都一样 意思就是说 if(!this.ispostback) { }这里面的,如果是页面第一次加载(或者按f5刷新)会执行里面的代码 如果是runat=server这样的控件导致的页面刷新,就不会执行里面的代码.

随州市18724581105: 1、动态网页和静态网页区别;2、isPostBack作用(举例说明)
栾虎亚胺: 静态网页一般指不含互动程序或只含有一些简单互动程序(如:js) 的HTML页面 ,维护困难,需要直接更改页面文件来改变页面的显示效果 动态页面是指能进行互动操作 有后台程序 数据库 的页面,如JSP ASP PHP 等,优势是功能 和 管理 ...

随州市18724581105: C#里ispoatback的具体用法 -
栾虎亚胺: 下面的示例演示如何进行测试的值 IsPostBack 属性以确定是否页上呈现第一次,或响应回发加载页面时. 如果第一次,所呈现页面时,代码将调用Page.Validate 方法.(未显示) 的页标记包含 RequiredFieldValidator 控件时,才为必填的输入字段不创建任何条目显示星号. 调用 Page.Validate 会导致立即页上呈现时,而不是等待,直到用户单击提交按钮显示星号. 回发后,无需调用 Page.Validate, ,这是因为该方法调用的一部分 Page 生命周期.

随州市18724581105: 关于if(!page.ispostback)的问题 -
栾虎亚胺: 使用Cookies技术!判断特定cookies值是否为空,如果是--IsPostBack==false,说明未提交表单(IsPostBack是用来判断是否提交表单的),弹出广告.当提交表单时,将值写入Cookies中,以防再次弹广告;如果不是--IsPostBack==true,则说明已经提交表单.至于读取与写入COOKIES,既可以使用客户端的JS,也可以使用ASP.

随州市18724581105: 请教各位ASP.net高手哥哥代码详细功能..
栾虎亚胺:第一段代码表示的是否是页面回传,换句不完全正确的话说就是:IsPostBack检查是否是从其它页面跳转到这个页面的, if (!this.IsPostBack)表示如果不是回传则换行{}里面的代码.第二段代码是用户登录代码的一部份,cmd.ExecuteScalar() 是返回在数据库中查寻的结果,如果查寻到满足条件的数据,则返回 满足条件的数据的条数,如果没有查寻到,则为0 ,条件 if (a > 0)表示查寻到了数据,说明用户存在且密码正确,所以跳转到~/guanliyuan/guanliindex.aspx 页面.否则 弹出对话框 很遗憾,用户名或密码错误!

随州市18724581105: HTTPHandler有什么作用 -
栾虎亚胺: 一 asp.net请求的处理过程 ------------------- HttpModule 必须要掌握的东西 HttpHandler 必须要掌握的东西,非常有用 以上两个的实例 --------------------- asp.net 事件模型机制 ----------------------- 一 客户的请求页面由aspnet_isapi.dll这个动态连接库来处...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网