I have a form with a Submit button. The user fills out the form,
clicks the submit button, and then the page posts back to itself.
Every time the page posts back to itself, the "Page_Load" event fires.
So if the user first types the URL of the page in the browser, the
"Page_Load" event fires. Then he hits submit, and the form contents
are posted back, so the "Page_Load" event fires again. The form
appears again (I clear its contents), and he can fill it again, click
submit, and the "Page_Load" event fires again.
I also have a validator control that gives an error message if the user
leaves a field blank. So if the user clicks submit without filling in
a field, the submit code checks "If Page.IsValid()" and puts an error
message on the page. I find that the "Page_Load" event is fired for
this too. In other words, if the form is incorrect and the user clicks
submit, the "Page_Load" event fires, probably just to put the error
message on the page.
Now in the Page_Load event, I want to store the form's contents in a
database. To do that, I have to know why Page_Load is firing. I don't
want to store the form contents if Page.IsPostBack is False, because
that means this is the first time the page is viewed, and the form
hasn't been filled out yet. I also don't want to store the form
contents if there is an error on the page, even though Page_Load is
fired in this case as well.
So I thought the easy way to to this would be to create a Session
variable that tells me if the submit button found the form fields to be
valid. The submit code would look like this:
''''''''''''''''''''''''''''
Sub SubmitClick(objSender As Object, objArgs As EventArgs)
If Page.IsValid() Then
LabDiagnostic.Text = "IS VALID"
Session("Valid") = True
Else
LabDiagnostic.Text = "NOT VALID"
Session("Valid") = False
End If
If Session("Valid") = True Then
LabDiagnostic2.Text = "Session('Valid') = True"
Else
LabDiagnostic2.Text = "Session('Valid') = False"
End If
End Sub
Notice that I put in Diagnostics just to be sure the code is working.
The diagnostics do show that it works.
Then in the "Page_Load" event, I test Session("Valid") again:
'''''''''''''''''''''''''''''''''
Sub Page_Load(Source As Object, E As EventArgs)
If Page.IsPostBack Then
If Session("Valid") = True Then
LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = True"
Else
LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = False"
End If
End If
End Sub
''''''''''''''''''''''''''''''''''''''''''''''''''
But this time the diagnostic gives the opposite result than I expect!
This is so strange that I feel I must be doing something obviously
wrong, but I can't tell what it is.
Here is the entire code of the page, in case someone wants to try it
out:
--- Thanks
--- Marvin
<%@Page Language="VB" debug="true" %>
<%@Import NameSpace="System.Data" %>
<%@ Import Namespace="System.Data.SqlClient" %>
<HTML>
<HEAD>
<TITLE>Enter Passenger Details</TITLE>
</HEAD>
<script language="VB" runat="server">
'''''''''''''''''''''''''''''''''
Sub Page_Load(Source As Object, E As EventArgs)
If Page.IsPostBack Then
If Session("Valid") = True Then
LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = True"
Else
LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = False"
End If
End If
End Sub
''''''''''''''''''''''''''''
Sub SubmitClick(objSender As Object, objArgs As EventArgs)
If Page.IsValid() Then
LabDiagnostic.Text = "IS VALID"
Session("Valid") = True
Else
LabDiagnostic.Text = "NOT VALID"
Session("Valid") = False
End If
If Session("Valid") = True Then
LabDiagnostic2.Text = "Session('Valid') = True"
Else
LabDiagnostic2.Text = "Session('Valid') = False"
End If
End Sub
'''''''''''''''''''''''''''''''''''''''''''''''''' '''''''
</script>
<BODY>
<form METHOD="POST" name="MyForm" runat="server">
<ASP:Label id="LabDiagnostic" runat="server" />
<hr>
<ASP:Label id="LabDiagnostic2" runat="server" />
<hr>
<ASP:Label id="LabDiagnostic3" runat="server" />
<center>
<table border="1">
<tr>
<td align="right">First Name</td>
<td><ASP:Textbox id="FirstName" MaxLength="40" Columns="40"
runat="server" />
<ASP:RequiredFieldValidator id="rfvFirstName" runat="server"
ControlToValidate="FirstName"
ErrorMessage="* You must enter a first name."
Display="dynamic">
*
</ASP:RequiredFieldValidator>
</td>
</tr>
<tr><td align="center" colspan="2">
<asp:Button id="MyButton" Text="Submit" runat="server"
OnClick="SubmitClick" />
</td></tr>
</table>
</center>
<center>
<table><tr><td>
<ASP:ValidationSummary id="valSummary" runat="server"
HeaderText = "<b>The following errors were found:</b>"
DisplayMode="List" ShowSummary="True" ShowMessageBox="True" />
<!-- normally I have ShowSummary="False" -->
</td></tr></table>
</center>
</form>
</BODY>
</HTML> 2 2183
The Page_Load event allways fires. When the page loads off it goes, every
time, no exception. Now in the Page_Load event, I want to store the form's contents in a database. To do that, I have to know why Page_Load is firing. I don't want to store the form contents if Page.IsPostBack is False, because that means this is the first time the page is viewed, and the form hasn't been filled out yet. I also don't want to store the form contents if there is an error on the page, even though Page_Load is fired in this case as well. So I thought the easy way to to this would be to create a Session variable that tells me if the submit button found the form fields to be valid. The submit code would look like this:
This is not that difficult really. The validators which operate client side
are your first attempt at ensuring that the data is consistant with what you
would like the user to do with it. The validators on the client side will
stop form submission if there criteria is not met.
When the page loads you can test to see if it is a postback and then further
validate from there.
if Page.IsPostback Then
if MyValidationFunction() Then
'Store My Data
Else
litMessage.Text = "Your form has an error on it . . . Blah Blah Blah "
End If
End If
--
Best Regards
The Inimitable Mr Newbie º¿º
"COHENMARVIN" <co*********@hotmail.com> wrote in message
news:11**********************@g49g2000cwa.googlegr oups.com...I have a form with a Submit button. The user fills out the form, clicks the submit button, and then the page posts back to itself. Every time the page posts back to itself, the "Page_Load" event fires. So if the user first types the URL of the page in the browser, the "Page_Load" event fires. Then he hits submit, and the form contents are posted back, so the "Page_Load" event fires again. The form appears again (I clear its contents), and he can fill it again, click submit, and the "Page_Load" event fires again. I also have a validator control that gives an error message if the user leaves a field blank. So if the user clicks submit without filling in a field, the submit code checks "If Page.IsValid()" and puts an error message on the page. I find that the "Page_Load" event is fired for this too. In other words, if the form is incorrect and the user clicks submit, the "Page_Load" event fires, probably just to put the error message on the page. Now in the Page_Load event, I want to store the form's contents in a database. To do that, I have to know why Page_Load is firing. I don't want to store the form contents if Page.IsPostBack is False, because that means this is the first time the page is viewed, and the form hasn't been filled out yet. I also don't want to store the form contents if there is an error on the page, even though Page_Load is fired in this case as well. So I thought the easy way to to this would be to create a Session variable that tells me if the submit button found the form fields to be valid. The submit code would look like this: '''''''''''''''''''''''''''' Sub SubmitClick(objSender As Object, objArgs As EventArgs) If Page.IsValid() Then LabDiagnostic.Text = "IS VALID" Session("Valid") = True Else LabDiagnostic.Text = "NOT VALID" Session("Valid") = False End If If Session("Valid") = True Then LabDiagnostic2.Text = "Session('Valid') = True" Else LabDiagnostic2.Text = "Session('Valid') = False" End If End Sub Notice that I put in Diagnostics just to be sure the code is working. The diagnostics do show that it works. Then in the "Page_Load" event, I test Session("Valid") again: ''''''''''''''''''''''''''''''''' Sub Page_Load(Source As Object, E As EventArgs)
If Page.IsPostBack Then If Session("Valid") = True Then LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = True" Else LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = False" End If End If End Sub '''''''''''''''''''''''''''''''''''''''''''''''''' But this time the diagnostic gives the opposite result than I expect! This is so strange that I feel I must be doing something obviously wrong, but I can't tell what it is. Here is the entire code of the page, in case someone wants to try it out: --- Thanks --- Marvin
<%@Page Language="VB" debug="true" %> <%@Import NameSpace="System.Data" %> <%@ Import Namespace="System.Data.SqlClient" %>
<HTML> <HEAD> <TITLE>Enter Passenger Details</TITLE> </HEAD>
<script language="VB" runat="server"> ''''''''''''''''''''''''''''''''' Sub Page_Load(Source As Object, E As EventArgs)
If Page.IsPostBack Then If Session("Valid") = True Then LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = True" Else LabDiagnostic3.Text = "PAGE_LOAD: Session('Valid') = False" End If End If End Sub '''''''''''''''''''''''''''' Sub SubmitClick(objSender As Object, objArgs As EventArgs) If Page.IsValid() Then LabDiagnostic.Text = "IS VALID" Session("Valid") = True Else LabDiagnostic.Text = "NOT VALID" Session("Valid") = False End If If Session("Valid") = True Then LabDiagnostic2.Text = "Session('Valid') = True" Else LabDiagnostic2.Text = "Session('Valid') = False" End If End Sub '''''''''''''''''''''''''''''''''''''''''''''''''' ''''''' </script>
<BODY> <form METHOD="POST" name="MyForm" runat="server"> <ASP:Label id="LabDiagnostic" runat="server" /> <hr> <ASP:Label id="LabDiagnostic2" runat="server" /> <hr> <ASP:Label id="LabDiagnostic3" runat="server" /> <center> <table border="1"> <tr> <td align="right">First Name</td> <td><ASP:Textbox id="FirstName" MaxLength="40" Columns="40" runat="server" /> <ASP:RequiredFieldValidator id="rfvFirstName" runat="server" ControlToValidate="FirstName" ErrorMessage="* You must enter a first name." Display="dynamic"> * </ASP:RequiredFieldValidator>
</td> </tr> <tr><td align="center" colspan="2"> <asp:Button id="MyButton" Text="Submit" runat="server" OnClick="SubmitClick" /> </td></tr>
</table> </center> <center> <table><tr><td> <ASP:ValidationSummary id="valSummary" runat="server" HeaderText = "<b>The following errors were found:</b>" DisplayMode="List" ShowSummary="True" ShowMessageBox="True" /> <!-- normally I have ShowSummary="False" --> </td></tr></table> </center> </form> </BODY> </HTML>
It seems that my problem was that I assumed the "Submit" button fires
its event before the "Page_Load" event. I had a form with a "Submit"
button, and I thought that when I clicked the "submit" button, the
first thing that would happen was that the code in the "submit" button
event would be executed, and only after that would a "Page_Load" be
executed. But the converse is true, when you click a "submit" button,
the first thing that happens is a "Page_Load", and only after that does
the server execute the code of the "submit" button event.
This is true using the "OnClick" event, the "OnServerClick" event
appears to be radically different, I don't know why.
-- Marvin This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics
by: Dot net work |
last post by:
Hi,
Make up a very simple project as follows:
1 aspx form
3 web user controls (referred to as A, B, and C)
"A" web user control:
Put 1 textbox and 1 button on this web user control. (You...
|
by: Kepler |
last post by:
I'm fighting a really strange bug that involves both a DataGrid and a
Repeater disappearing on postback. The strange thing is that I've
distilled the problem down to a simple program, that...
|
by: Tim_Mac |
last post by:
hi,
i have an aspx page which dynamically loads a user control and adds it
to a placeholder. the control is recreated and added to the
placeholder for postbacks as well.
the user control...
|
by: William Sullivan |
last post by:
I have an extremely weird problem that I have no idea how to approach.
I have a simple page with a search textbox and a search button. The button
causes a postback, where I perform the search and...
|
by: Mossman |
last post by:
Hello,
I will discuss at a high level what is happening on an ASP.NET web page
I developed a year ago in ASP.NET using Visual Studio 2003 and
currently support.
I have an ASP.NET web page...
|
by: Mr Newbie |
last post by:
OK, I have a fairly simple setup where I have an Index of records which are
displayed using a datagrid on a page. When you click the link associated
with a Row (ArticleID) , this ID is passed to a...
|
by: savvy |
last post by:
I'm having some background graphics layout on the page and a table
layout on top of it. Inside the table i have two DropDownList menus
whose AutoPostBack Property is set to true and I'm using two...
|
by: Tim_Mac |
last post by:
hi,
using .net 2.0, i have a web form with lots of textboxes, drop-down-lists
etc. There are lots of required field validators and regular expression
validators. When i click the 'save' button,...
|
by: riteshjain1982 |
last post by:
Pagepostback.....strange problem
Hi,
I am at cient place and getting very strange problem with my asp.net application............when i call my web application from any desktop machine in lan...
|
by: BarryA |
last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
|
by: Hystou |
last post by:
There are some requirements for setting up RAID:
1. The motherboard and BIOS support RAID configuration.
2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
|
by: marktang |
last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
|
by: Oralloy |
last post by:
Hello folks,
I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>".
The problem is that using the GNU compilers,...
|
by: jinu1996 |
last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
|
by: Hystou |
last post by:
Overview:
Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
|
by: tracyyun |
last post by:
Dear forum friends,
With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
|
by: agi2029 |
last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM).
In this session, we are pleased to welcome a new...
| |