aboutsummaryrefslogtreecommitdiffstats
path: root/documentation/components
diff options
context:
space:
mode:
Diffstat (limited to 'documentation/components')
-rw-r--r--documentation/components/components-textfield.asciidoc31
1 files changed, 5 insertions, 26 deletions
diff --git a/documentation/components/components-textfield.asciidoc b/documentation/components/components-textfield.asciidoc
index e59b38bbf7..016ced3c58 100644
--- a/documentation/components/components-textfield.asciidoc
+++ b/documentation/components/components-textfield.asciidoc
@@ -9,14 +9,12 @@ layout: page
((("[classname]#TextField#", id="term.components.textfield", range="startofrange")))
-
[classname]#TextField# is one of the most commonly used user interface
components. It is a [classname]#Field# component that allows entering textual
values using keyboard.
The following example creates a simple text field:
-
[source, java]
----
// Create a text field
@@ -38,7 +36,6 @@ in most other fields. The value can be acquired with [methodname]#getValue()#
directly from the text field, as is done in the example below, or from the
property reference of the event.
-
[source, java]
----
// Handle changes in the value
@@ -67,7 +64,7 @@ single-line text fields.
[[figure.components.textfield.api]]
.Text Field Class Relationships
-image::img/textfield-diagram-hi.png[]
+image::img/textfield-diagram-hi.png[width=50%]
[[components.textfield.databinding]]
== Data Binding
@@ -77,7 +74,6 @@ any property type that has a proper converter, as described in
<<dummy/../../../framework/datamodel/datamodel-properties#datamodel.properties.converter,"Converting
Between Property Type and Representation">>.
-
[source, java]
----
// Have an initial data model. As Double is unmodificable and
@@ -116,7 +112,6 @@ the Values in a Table">>, and
<<dummy/../../../framework/datamodel/datamodel-itembinding#datamodel.itembinding,"Creating
Forms by Binding Fields to Items">> regarding forms.
-Bean Binding
[[components.textfield.length]]
== String Length
@@ -129,21 +124,15 @@ length property is defined at [classname]#AbstractTextField# level.
Notice that the maximum length setting does not affect the width of the field.
You can set the width with [methodname]#setWidth()#, as with other components.
Using __em__ widths is recommended to better approximate the proper width in
-relation to the size of the used font. There is no standard way in HTML for
-setting the width exactly to a number of letters (in a monospaced font). You can
-trick your way around this restriction by putting the text field in an
-undefined-width [classname]#VerticalLayout# together with an undefined-width
-[classname]#Label# that contains a sample text, and setting the width of the
-text field as 100%. The layout will get its width from the label, and the text
-field will use that.
-
-Fitting TextField width to fixed input length
+relation to the size of the used font, but the __em__ width is not exactly the
+width of a letter and varies by browser and operating system. There is no standard
+way in HTML for setting the width exactly to a number of letters (in a monospaced font).
+
[[components.textfield.nullvalues]]
== Handling Null Values
((("Null representation", id="term.components.textfield.nullvalues", range="startofrange")))
-
((("[methodname]#setNullRepresentation()#")))
As with any field, the value of a [classname]#TextField# can be set as
[parameter]#null#. This occurs most commonly when you create a new field without
@@ -164,7 +153,6 @@ representation string sets the value as the literal value of the string, not
null. This default assumption is a safeguard for data sources that may not allow
null values.
-
[source, java]
----
// Have a property with null value
@@ -196,7 +184,6 @@ image::img/textfield-nullrepresentation.png[]
((("[classname]#Text change events#", id="term.components.textfield.textchangeevents", range="startofrange")))
-
Often you want to receive a change event immediately when the text field value
changes. The __immediate__ mode is not literally immediate, as the changes are
transmitted only after the field loses focus. In the other extreme, using
@@ -210,7 +197,6 @@ Text change events are received with a [classname]#TextChangeListener#, as is
done in the following example that demonstrates how to create a text length
counter:
-
[source, java]
----
// Text field with maximum length
@@ -278,14 +264,11 @@ sequentially one after another. Change events are nevertheless communicated
asynchronously to the server, so further input can be typed while event requests
are being processed.
-
-
(((range="endofrange", startref="term.components.textfield.textchangeevents")))
[[components.textfield.css]]
== CSS Style Rules
-
[source, css]
----
.v-textfield { }
@@ -296,7 +279,6 @@ only of an element with the [literal]#++v-textfield++# style.
For example, the following custom style uses dashed border:
-
[source, css]
----
.v-textfield-dashing {
@@ -317,7 +299,4 @@ that contain a text input field, even if the text input is not an actual
[classname]#TextField#. This ensures that the style of different text input
boxes is similar.
-
(((range="endofrange", startref="term.components.textfield")))
-
-