dijit.form.TextBox

Authors:Becky Gibson, Doug Hays, Bill Keese, Nikolai Onken, Marcus Reimann, Craig Riecke
Developers:Doug Hays, Bill Keese
Available:since V1.0

TextBox is a basic <input type=”text”>-style form control.

Introduction

dijit.form.TextBox has rudimentary text-scrubbing functions that trim or proper-casify text, but it does not validate the entered text. Like all Dijit controls, TextBox inherits the design theme, so it’s better to use this than an HTML control, even if you don’t have to do any input scrubbing. However:

Examples

Declarative example

<script type="text/javascript">
dojo.require("dijit.form.TextBox");
</script>
<input type="text" name="firstname" value="testing testing"
        dojoType="dijit.form.TextBox"
        trim="true" id="firstname"
        propercase="true">
<label for="firstname">Auto-trimming, Proper-casing Textbox:</label>

Sizing TextBoxes

Sizing a text box is done through the CSS width on the text box dom node. Typically this is done by specifying the width in ems. Please see the following for an example:

<script>
  dojo.require("dijit.form.TextBox");

  function init() {
    var box = dijit.byId("progBox");
    dojo.style(box.domNode, "width", "5em");
  }
  dojo.addOnLoad(init);
</script>
<b>A default textbox:</b> <div dojoType="dijit.form.TextBox"></div>
<br>
<b>A large textbox:</b> <div style="width: 50em;" dojoType="dijit.form.TextBox"></div>
<br>
<b>A small textbox:</b> <div style="width: 10em;" dojoType="dijit.form.TextBox"></div>
<br>

<b>A programmatically sized textbox:</b> <div id="progBox" dojoType="dijit.form.TextBox"></div>
<br>
<style type="text/css">
</style>

Getting and Manipulating the Value

Getting and manipulating the value is a trivial matter. It is done through the attr() function of the widget. Please see the following example for more detail:

<script>
  dojo.require("dijit.form.TextBox");

  function init() {
    var box0 = dijit.byId("value0Box");
    var box1 = dijit.byId("value1Box");
    box1.attr("value", box0.attr("value") + " modified");
    dojo.connect(box0, "onChange", function(){
       box1.attr("value", box0.attr("value") + " modified");
    });
  }
  dojo.addOnLoad(init);
</script>
<b>A textbox with a value:</b> <input id="value0Box" dojoType="dijit.form.TextBox" value="Some value" intermediateChanges="true"></input>
<br>
<b>A textbox set with a value from the above textbox:</b> <input id="value1Box" dojoType="dijit.form.TextBox"></input>
<br>
<style type="text/css">
</style>

Using the placeholder parameter

Coming with Dojo 1.5 the HTML5 placeholder parameter (also known as a “hint”) has been implemented for all TextBox based widgets. Placeholder is gray example or hint text that the widget displays inside the input area of empty form fields, such as “John Doe” or “Your Name”. The text disappears when the user focuses the field.

In order to use it, submit a parameter “placeHolder” to your widget:

myTextBox = new dijit.form.TextBox({
    name: "firstname",
    value: "" /* no or empty value! */,
    placeHolder: "type in your name"
}, "firstname");

Accessibility

Keyboard

The TextBox widget uses native HTML INPUT (type=text) controls.

Error in the documentation? Can’t find what you are looking for? Let us know!