How to write Lost focus method for asp.net text method? Please anybody have any idea to write this, share with me?
The LostFocus event occurs after the Exit event. If you move the focus to a control on a form, and that control doesn't have the focus on that form, the Exit and LostFocus events for the control that does have the focus on the form occur before the Enter and GotFocus events for the control you moved to.
To set focus on an ASP.NET Web server controlCall the control's Focus method. -or- Call the page's SetFocus method, passing it the ID of the control on which you want to set focus.
So I know everyone has shown the basic client side approach, and that is fine, but I wanted to at least show a solution for handling a specific client side event on the server.
Lets take a look at the code, and go over it piece by piece.
Since ASP.Net TextBox does not expose a server side event for OnBlur, you will have to do it manually. Fortunately this is pretty easy to achieve. Suppose you have this small bit of code in your .aspx page. You want to update a Label control server side whenever the TextBox loses focus.
<asp:Label ID="lblOnBlur" runat="server">On Blur Example</asp:Label><br /> <asp:TextBox ID="tbOnBlur" runat="server" ClientIDMode="Static" /><br /> <asp:Label ID="lblOutput" runat="server" />
ASP.Net has a built in client side function that gets called to trigger postbacks that takes two parameters:
You could just wireup the event in markup by adding the following attribute and value to your TextBox:
onblur="__doPostBack('tbOnBlur','OnBlur');"
However, the framework has an easy way to generate this script for you server side. In your Page_Init method, simply add a call to GetPostBackEventReference
and assign it to the "onblur" attribute for you control like so:
protected void Page_Init(object sender, EventArgs e) { var onBlurScript = Page.ClientScript.GetPostBackEventReference(tbOnBlur, "OnBlur"); tbOnBlur.Attributes.Add("onblur", onBlurScript); }
With standard server control events, the event wireup and invocation is handled automagically for you by implementing IPostBackEventHandler
. That is a lot of work for a one-off solution, so lets just handle it manually by inspecting the request params.
protected void Page_Load(object sender, EventArgs e) { if (IsPostBack) { var ctrlName = Request.Params[Page.postEventSourceID]; var args = Request.Params[Page.postEventArgumentID]; HandleCustomPostbackEvent(ctrlName, args); } } private void HandleCustomPostbackEvent(string ctrlName, string args) { //Since this will get called for every postback, we only // want to handle a specific combination of control // and argument. if (ctrlName == tbOnBlur.UniqueID && args == "OnBlur") { lblOutput.Text = "On Blur Event Handled Server Side!" + DateTime.Now; } }
In the end it isn't terribly difficult to simulate server side events if you don't mind digging into the framework a little.
Hope this helps!
Cheers,
Josh
If you want the server to do something after the textbox loses focus you can add AutoPostback="True" and, if you don't want the postback to reload the whole page, use an UpdatePanel:
<asp:ScriptManager ID="ScriptManager1" runat="server" />
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<asp:TextBox ID="TextBox1" runat="server" AutoPostBack="true"
OnTextChanged="TextBox1_TextChanged" />
</ContentTemplate>
</asp:UpdatePanel>
The function TextBox1_TextChanged can then do something with the text (serverside).
if (!Page.IsPostBack)
{
txtName.Attributes.Add("onblur","alert('Hello world')");
}
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