I have a textbox on my website:
<asp:TextBox ID="Latitude" runat="server" ClientIDMode="Static" ></asp:TextBox>
On page load I fill that textbox with something from a databse:
protected void Page_Load(object sender, EventArgs e)
{
Latitude.Text = thisPlace.Latitude;
}
When I want to update my databse with a new value in that textbox, it still updated the database with the one put in on page load:
protected void Save_Click(object sender, EventArgs e)
{
setCoordinates(Latitude.Text);
}
How can I make sure that setCoordinates()
retrieves the new value from the textbox and not the initial value from the database from Latitude.Text = thisPlace.Latitude;
?
I think its because PostBack
If you're calling setCoordinates()
on some button's click event textbox's new value will be lost. If that's right change Page_Load
like this one
protected void Page_Load(object sender, EventArgs e)
{
if(!IsPostBack)
{
Latitude.Text = thisPlace.Latitude;
}
}
This is because the Page_Load
event happens before your method setCoordinates
is called. This mean that the Latitude.Text value is the same as before.
You should change the load function so it does not always set the initial value of the textbox.
By changing the page_load event with !Page.IsPostBack
, the only time the initial value is given, is the first time the page originaly loads.
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
Latitude.Text = thisPlace.Latitude;
}
}
Page_Load
executed each time page is loaded. Add IsPostBack
check to reset text only on first page load:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
Latitude.Text = thisPlace.Latitude;
}
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With