This page is part of a static HTML representation of the TiddlyWiki at https://tiddlywiki.com/
SelectWidget
13th November 2023 at 9:33am
TriggeringWidgetsWidgets
Introduction
The select widget displays a popup menu based on a HTML select element. The popup (or dropdown) contains a list of items defined by <option> and <optgroup> elements.
Every time the user selects a new value in the menu, the selected value is written to the text of a specified tiddler field or index and any ActionWidgets within the actions attribute are triggered. Conversely, if the tiddler value is changed independently the select widget is automatically updated to reflect the new value.
In multiple selection mode, the list of selected values is bound to the specified tiddler field or index. Browsers generally use the ctrl or cmd keys for multiple selection.
For example, this select widget displays a list of the tags in this wiki:
See the text change as you switch entries in the select widget. Try changing the value of the state tiddler and see the select widget change. Notice how the select widget only displays an entry if there is a precise match with the tiddler text.
Content and Attributes
The content of the <$select> widget should be one or more HTML <option> or <optiongroup> elements that provide the available values.
Attribute
Description
tiddler
The title of the tiddler containing the value to be displayed/modified by the select widget (defaults to the current tiddler)
field
The field name for the value in the current tiddler (defaults to "text")
index
The index of a property in a DataTiddler (takes precedence over the field attribute)
class
CSS classes to be assigned to the HTML select element
tooltip
Optional tooltip
default
Default value to be used if the tiddler, field or index specifies a missing value
multiple
If present, switches to multiple selection mode
size
The number of rows to display in multiple selection mode
actions
A string containing ActionWidgets to be triggered when the key combination is detected
focus
Introduced in v5.2.4 Optional. Set to "yes" to automatically focus the HTML select element after creation
tabindex
New in v5.3.1 Optional. Sets the tabindex attribute of the HTML select element to the given value
This example sets the title of the current wiki $:/SiteTitle to one of a list of book titles:
<$select tiddler='$:/SiteTitle' tooltip='Choose a new site title'>
<option>A Tale of Two Cities</option>
<option>A New Kind of Science</option>
<option>The Dice Man</option>
</$select>
That renders as:
Simple List with Placeholder Value
To display a default value that is also disabled, effectively functioning as a placeholder, the following form can be used. Note that the targeted field must be empty, or not exist, for the placeholder to show in the widget:
<$select tiddler='New Tiddler' field='text' default='Choose a new text'>
<option disabled>Choose a new text</option>
<option>A Tale of Two Cities</option>
<option>A New Kind of Science</option>
<option>The Dice Man</option>
</$select>
That renders as:
Value lists
In this example the value attribute has been used to specify the text that should be used as the value of the entry instead of the display text.
<$select tiddler='$:/SiteTitle'>
<option value='cities'>A Tale of Two Cities</option>
<option value='science'>A New Kind of Science</option>
<option value='dice'>The Dice Man</option>
</$select>
That renders as:
Option Groups
Entries in the list can be grouped together with the <optgroup> element
<$select tiddler='$:/SiteTitle'>
<optgroup label='Fiction'>
<option value='cities'>A Tale of Two Cities</option>
<option value='dice'>The Dice Man</option>
</optgroup>
<optgroup label='Non-fiction'>
<option value='science'>A New Kind of Science</option>
<option value='recursive'>The Recursive Universe</option>
</optgroup>
</$select>
That renders as:
Generated Lists
The ListWidget can be used to generate the options for a select widget. For example, here we combine a select widget listing all the tiddlers tagged TableOfContents with a transclusion to display the text of the selected one.