Naming convention for controls

64,858

Solution 1

I don't have a convention as such, but I do try to be very broad with the 'type' portion of the name. e.g. Button, Link Button, Image Button tend to be named 'somethingButton'. Combo boxes, radio button lists all end up as 'somethingSelector'. TextBoxes and Calendars are 'somethingInput'. That way I get a rough idea of what sort of control it is without the name being tied to the actual implementation. If I decide to replace an option button group with a dropdown then no need to rename!

Solution 2

Caveat: The following is more directed at WinForm/WPF development. Patrick Peters rightly pointed out that there are bandwidth/performance issues at play when dealing with ASP.NET controls.

There isn't really a standard here, and I believe that this is because its one of the most arbitrary naming scenarios. In most cases, controls are private to the class, and only used lightly in event handlers.

Like other answerers, I too used to spend a non-trivial amount of time "fixing" control names. I would do things like "btnSave", "tbxName" (tbx for TextBox), etc. However, when explaining my scheme to someone else, I realized how arbitrary that was. Is "cbx" a ComboBox or a Checkbox?

This led me to re-examine what the designer does automatically and realize that I can clearly, consistently, and quickly name controls if I let the designer do the work. Its actually very similar to the suggestion of the question poster:

I replace the control number with the semantics of the control. Thus "button1" (the designer default) will be "buttonSave", and "listBox3" will become "listBoxWidgets". If there will only be one control of that type, I just remove the number: "errorProvider1" becomes "errorProvider".

So how is this better?

  • Meticulously "fixing" variable names is a waste of time if its an internal variable
  • Your naming scheme is likely to be ambiguous if it shortens a whole bunch of stuff (CheckBox versus ComboBox)
  • The designer gives a good, consistent starting point that is easy (and quick) to specialize
  • The length of the variable name is irrelevant when you use Intellisense
  • Control names group nicely and intuitively (in Intellisense) when prefaced by their type. When you have 15 TextBoxes on your Form, you just first remember you want a TextBox , type "textBox", and then pick the name from the list.
  • Anyone unfamiliar with your "scheme" can see it immediately and adopt it quicker than anything else.
  • It is VERY fast to provide useful control names...very little keyboard/mouse jockeying to do this...so high productivity with intuitive results. What is not to like?

PS. This is tending towards a Bikeshed question, but as I can paint a bikeshed, I went ahead and joined the discussion. ;)

Solution 3

Here are some common ones:

frm  Form
mnu  Form menu
cmd  Command button
chk  Check button
opt  Radio button
lbl  Text label
txt  Text edit box
pb   Picture box
pic  Picture
lst  List box
cbo  Combo box
tmr  Timer

A longer list is at INFO: Object Hungarian Notation Naming Conventions for VB.

Solution 4

I don't do WinForms for quite some time but what I did was two things.

  • uncheck 'generate member' (or however it is called) for things like labels, etc. Basically ensuring I keep as fields only things I need.
  • for those I need, set descriptive name. It if is necessary, append the name of the control (ie saveButton). If I don't feel like adding a control name adds any value I would not append the 'Button' and leave the name simply as 'save'.

Basically most of the time I would not create a member for save button at all. (If you have some save logic you still can have only OnSaving event handler subscribed to the button's Click event).

https://msdn.microsoft.com/en-us/library/ms233630(v=vs.110).aspx

Solution 5

Yes change those names

For me:

  • Button btnDescription

  • TextBox txtDescription

  • ComboBox cboDescription

etc...

Share:
64,858
TestyTest
Author by

TestyTest

Senior .NET C# developer and technical architect.

Updated on March 23, 2020

Comments

  • TestyTest
    TestyTest about 4 years

    Microsoft has naming guidelines on their website (here). Also I have the Framework Design Guidelines book.

    What I could not find was a guideline about naming controls.

    For example, a button, when dropped to a form, gets the typename + number, camel-cased as default name, such as "button1".

    This is what I do: I delete the number and add a meaningful description after. For example "buttonDelete" or "buttonSave".

    This way you do not have to maintain a big list of controls and their abbreviated names in a guideline somewhere.

    Do you agree?