ASP.NET Custom Server Controls: Cute ASP.NET TextBox with Help Tips - Briefly understanding the JavaScript implementation
(Page 5 of 5 )
As you understand by now, my control needs to work with JavaScript (to display help tips dynamically), so I implemented each of those JavaScripts as separate methods which together can be registered to the page within the "AddAttributesToRender” method. The following are the four core methods which emit their respective JavaScripts:
getJS4GotFocus
getJS4LostFocus
getJS4MouseOver
getJS4MouseOut
All of the above user-defined methods (which emit JavaScripts), together with the following code-fragment, made it convenient for me to achieve what I expected:
'emit javascript only at run-time
If Not IsDesignTime Then
'focus events
If Me.ShowHelpTipsOnFocus Then
If Not Page.IsStartupScriptRegistered(Me.UniqueID
& "_GotFocus") Then
Page.RegisterStartupScript(Me.UniqueID &
"_GotFocus", getJS4GotFocus(Me.UniqueID))
End If
If Not Page.IsStartupScriptRegistered(Me.UniqueID
& "_LostFocus") Then
Page.RegisterStartupScript(Me.UniqueID &
"_LostFocus", getJS4LostFocus(Me.UniqueID))
End If
writer.AddAttribute("onFocus", Me.UniqueID &
"_GotFocus();")
writer.AddAttribute("onBlur", Me.UniqueID &
"_LostFocus();")
End If
'mouse events
If Me.ShowHelpTipsOnMouse Then
If Not Page.IsStartupScriptRegistered(Me.UniqueID
& "_MouseOver") Then
Page.RegisterStartupScript(Me.UniqueID &
"_MouseOver", getJS4MouseOver(Me.UniqueID))
End If
If Not Page.IsStartupScriptRegistered(Me.UniqueID
& "_MouseOut") Then
Page.RegisterStartupScript(Me.UniqueID &
"_MouseOut", getJS4MouseOut(Me.UniqueID))
End If
writer.AddAttribute("onMouseOver", Me.UniqueID &
"_MouseOver();")
writer.AddAttribute("onMouseOut", Me.UniqueID &
"_MouseOut();")
End If
End If
Remarks
This control has been developed just to initiate and show the power of custom controls to control everything right from the beginning through to the end, including client-side JavaScript emission. I didn’t quite implement all of the features of original ASP.NET Textbox control (as it would take a series of articles). You just need to learn a few more interfaces and methods to implement all of the original features along with your own features.
I leave it to the developers to further enhance the same control. The areas for improving the control would include eventing, better JavaScript for validation, data-binding, and so on. Good luck.
Any comments, suggestions, bugs, errors, feedback etc. are highly appreciated at jag_chat@yahoo.com.
| DISCLAIMER: The content provided in this article is not warranted or guaranteed by Developer Shed, Inc. The content provided is intended for entertainment and/or educational purposes in order to introduce to the reader key ideas, concepts, and/or product reviews. As such it is incumbent upon the reader to employ real-world tactics for security and implementation of best practices. We are not liable for any negative consequences that may result from implementing any information covered in our articles or tutorials. If this is a hardware review, it is not recommended to open and/or modify your hardware. |