input

February 6, 2015 ยท View on GitHub

Use this block for creating different types of text fields.

Overview

Modifiers of the block

ModifierAcceptable valuesUse casesDescription
type'password', 'search'BEMJSONThe type of the text field.
width'available'BEMJSONThe maximum allowed width of the text field.
has-cleartrueBEMJSONThe element that clears the input field content.
disabledtrueBEMJSON, JSThe disabled state.
focusedtrueBEMJSON, JSThe block is in focus.
theme'islands'BEMJSONA custom design.
size's', 'm', 'l', 'xl'BEMJSONThe size of the text field. Use sizes only for text fields when the theme modifier is set to islands.

Custom fields of the block

FieldTypeDescription
nameStringThe unique block name.
valString, NumberDefault content of the text field.
placeholderStringThe hint in the text field.
maxLengthStringThe maximum number of characters allowed in the text field.
autocompleteBooleanBrowser predictions of the rest of a word while a user is typing.
idStringThe unique identifier of the text field.
tabIndexNumberThe order when navigating through controls on a page by pressing the Tab key.

Block description

Use the input block to control the size, state and appearance of the text fields.

Modifiers of the block

type modifier

Acceptable values:'password', 'search'.

Use case: BEMJSON.

This modifier changes types of the text fields.

If the type modifier is not set, the input block is a common text field by default.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm' },
    placeholder : 'Enter your name'
}
Password field (type modifier with password value)

Use to create the specialized text fields for a password entry. For security reasons, the password field does not show the characters that the user types. Instead, the field displays the character different from the one typed such as an asterisk '*' (depends on a browser).

{
    block : 'input',
    mods : { theme : 'islands', size: 'm', type : 'password' },
    placeholder : 'Enter the password'
}
Search field (type modifier with search value)

Use to create the search field.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm', type : 'search' },
    placeholder : 'Enter your question'
}

width modifier

Acceptable value:'available'.

Use cases: BEMJSON.

Use to set the maximum available width to the text field.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm', width : 'available' },
    placeholder : 'Enter your name'
}

has-clear modifier

Acceptable value:true.

Use cases: BEMJSON.

Use this modifier to add the clear element into the text field to remove entered content.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm', 'has-clear' : true },
    val : 'Hello!'
}

disabled modifier

Acceptable value:true.

Use cases: BEMJSON, JS.

The modifier makes the block inactive. The disabled block is visible but not available for user actions.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm', disabled : true },
    placeholder : 'Enter your name'
}

focused modifier

Acceptable value:true.

Use cases: BEMJSON, JS.

The modifier puts the focus on the block.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm', focused : true },
    placeholder : 'Enter your name'
}

theme modifier

Acceptable value:'islands'.

Use case: BEMJSON.

The modifier gives the block a custom design.

The islands theme requires the size modifier.

{
    block : 'input',
    mods : { theme : 'islands', size: 'm', type : 'search' },
    placeholder : 'Enter your question'
}

size modifier

Acceptable values for the islands theme: 's', 'm', 'l', 'xl'.

Use case: BEMJSON.

Use the size modifier only for blocks with the islands theme.

Sets the size value for all types of text fields.

s

{
    block : 'input',
    mods : { theme : 'islands', size: 's' },
    placeholder : 'Size s'
}

m

{
    block : 'input',
    mods : { theme : 'islands', size: 'm' },
    placeholder : 'Size m'
}

l

{
    block : 'input',
    mods : { theme : 'islands', size: 'l' },
    placeholder : 'Size l'
}

xl

{
    block : 'input',
    mods : { theme : 'islands', size: 'xl' },
    placeholder : 'Size xl'
}

Custom fields of the block

name field

Type: String.

Specifies the block unique name.

{
    block : 'input',
    mods : { theme : 'islands', size: 'm' },
    name : 'Statistics'
}

val field

Type: String.

Specifies the content of the text field.

{
    block : 'input',
    mods : { theme : 'islands', size: 'm' },
    name : 'Statistics',
    val : 'Hello'
}

placeholder field

Type: String.

Specifies the hint in the text field.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm' },
    placeholder : 'Enter your name'
}

maxLength field

Type: Number.

Specifies the maximum number of characters allowed in the text field.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm' },
    placeholder : 'Enter your name',
    maxLength : 20
}

autocomplete field

Type: Boolean.

Specifies the browser predictions of the rest of the word while a user is typing.

If the autocomplete field is not specified, the autocomplete function is turned on by default.

To turn off the autocomplete function, use the false value:

{
    block : 'input',
    mods : { theme : 'islands', size : 'm' },
    placeholder : 'Enter your name',
    autocomplete : false
}

id field

Type: String.

Specifies the text field unique ID.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm' },
    placeholder : 'Enter your name',
    id : 'Unique_1'
}

tabIndex field

Type: Number.

Specifies the tab order when pressing Tab to navigate between controls on a page.

{
    block : 'input',
    mods : { theme : 'islands', size : 'm' },
    placeholder : 'Enter your name',
    tabIndex : 3
}