Jump to content

Tab key

From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by 83.244.252.5 (talk) at 16:48, 11 March 2013 (Tabs in HTML). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.
Tab key on a standard Windows keyboard (on upper left)

Tab key (abbreviation of tabulator key[1] or tabular key[2]) on a keyboard is used to advance the cursor to the next tab stop.

The word tab derives from the word tabulate, which means "to arrange data in a tabular, or table, form." When a person wanted to type a table (of numbers or text) on a typewriter, there was a lot of time-consuming and repetitive use of the space bar and backspace key. To simplify this, a horizontal bar was placed in the mechanism with a moveable lever stop for every position across the page. Initially these were set by hand, but later tab set and tab clear keys were added. When the tab key was depressed, the carriage advanced to the next tab stop. These were set to correspond to the particular column locations of the table, hence tab, being worked on. The tab mechanism also came into its own as a rapid and consistent way of uniformly indenting the first line of each paragraph.

In many programming languages the escape code \t can be used to insert a tab character.

Usage

In word processor applications, the Tab key typically moves the cursor to the next tab stop. In most other graphical applications, the Tab key will shift the focus to the next control or widget.

Tab characters

Several tab characters are included as ASCII control characters, used for text alignment. The most known and common tab is a horizontal tab (HT), which in ASCII has the decimal character code of 9, and may be referred to as control+I or ^I. A vertical tab (VT) also exists and has ASCII decimal character code 11 (control+K or ^K). In EBCDIC the code for HT is 5, and VT is 11 (the same as in ASCII). The horizontal tab is usually generated by the Tab key on a standard keyboard.

Originally, printer mechanisms used mechanical tab stops to indicate where the tabs went. This was done horizontally with movable metal prongs in a row, and vertically with a loop of mylar or other tape the length of a page with holes punched in it to indicate the tab stops. Initially these were manually set up to match the preprinted forms that were loaded into the printer. Later, the intention was to have the machine be pre-programmed, by using other control characters to set and clear the stops: ISO 6429 includes the codes 136 (Horizontal Tabulation Set), 137 (Horizontal Tabulation with Justification) and 138 (Vertical Tabulation Set).

In practice, settable tab stops were rather quickly replaced with fixed tab stops, de facto standardized at every multiple of 8 characters horizontally, and every 6 lines vertically (typically one inch vertically). A printing program could easily send the necessary spaces or line feeds to move to any position wanted on a form, and this was far more reliable than the modal and non-standard methods of setting tab stops. Tab characters simply became a form of data compression.

A common horizontal tab size of eight characters evolved, despite five characters being half an inch and the typical paragraph indentation of the time, because as a power of two it was easier to calculate in binary for the limited digital electronics available.

Tab-separated values (TSV)

Tab-separated values (TSV) are a common de facto standard for exporting and importing database or spreadsheet field values. Text divided into fields delimited by tabs can often be pasted into a word processor and formatted into a table with a single command.[further explanation needed]

The TSV convention for exporting data may be compared to the alternative comma-separated values (CSV) convention.

Gopher menus use tab-separated values to indicate selectors.

Tabs in HTML

HTML represents the horizontal tab as &#9;[3] but as with all whitespace characters this does not allow actual insertion of tabs into the page except inside <pre></pre> tags or elements with CSS attribute white-space set to pre.

Here is an example showing the use of &#9; with <pre></pre> tags. If you write in HTML:

These 2 lines are tabbed:
2009&#9;This line uses a tab.
&#9;This line also uses a tab.
This line does not use a tab.

The result would be something like this:

These 2 lines are tabbed:
2009	This line uses a tab.
	This line also uses a tab.
This line does not use a tab.

The vertical tab is &#xB; but is not allowed in SGML, including HTML and XML 1.0.[citation needed]

CSS

The issue is of concern in the use of CSS, which asserts that in an element where white space is to be preserved:

... 2. All tabs (U+0009) are rendered as a horizontal shift that lines up the start edge of the next glyph with the next tab stop. Tab stops occur at points that are multiples of 8 times the width of a space (U+0020) rendered in the block's font from the block's starting content edge.

CSS 3 defines tab-size property, which adjusts the default number of spaces for the tab character.[4] The latest version of WebKit supports it. The Opera web browser supports the -o-tab-size CSS property, the Firefox web browser supports the -moz-tab-size CSS property with the same meaning.[5]

JavaScript

In Javascript, tabs can be represented using escape characters as in \t or \x09.[6]

See also

References

  1. ^ "Underwood Portable Typewriter Gallery". Retrieved 2011-04-09.
  2. ^ "Instructions for Using the Underwood Typewriter". Retrieved 2011-04-09.
  3. ^ See Character encodings in HTML#HTML character references
  4. ^ "CSS 3 tab-size property W3 specification".
  5. ^ "CSS tab-size property on Mozilla Developer Network".
  6. ^ http://www.ecma-international.org/publications/standards/Ecma-262.htm Section 7.8.4 String Literals
Esc F1 F2 F3 F4 F5 F6 F7 F8 F9 F10 F11 F12 PrtScn/
SysRq
Scroll
Lock
Pause/
Break
TildeExclamation markAt signNumber signDollar signPercent signCaretAmpersandAsteriskParenthesisParenthesisUnderscorePlus signBackspaceBacktick1 (number)2 (number)3 (number)4 (number)5 (number)6 (number)7 (number)8 (number)9 (number)0Hyphen-minusEquals signBackspaceTab keyQWERTYUIOPCurly bracketCurly bracketVertical barTab keyQWERTYUIOPSquare bracketSquare bracketBackslashCaps lockASDFGHJKLColon (punctuation)Quotation markEnter keyCaps lockASDFGHJKLSemicolonApostropheEnter keyShift keyZXCVBNMBracketBracketQuestion markShift keyShift keyZXCVBNMComma (punctuation)Full stopSlash (punctuation)Shift keyControl keyWindows keyAlt keySpace barAlt keythumbMenu keyControl key
Insert Home PgUp Num
Lock
Delete End PgDn 7 8 9 +
4 5 6
1 2 3 Enter
   0
   Ins
 . 
Del