A combo box is a text box with a list box attached. This type of control enables users to select a predefined value in a list or type their own value in the text box portion of the control. The list is hidden until the user clicks the arrow next to the box.
In this article
When to use a combo box
Use a combo box when you want to:
-
Enable users to either select a predefined value from a list of choices or type their own value.
-
Hide list items on the form by default.
-
Display values retrieved from a fixed list, from the form template's data source, or from an external data source, such as a database or Microsoft Windows SharePoint Services list.
In the following illustration, users categorize expenses in an expense report form by selecting values in a combo box. If they don't see the value that they need, they can type it in the box instead of selecting a value in the list. In this example, the user is in the process of typing the words Phone/Fax.
After you insert a combo box on your form template, you must specify the values that you want to appear in it. Otherwise, users will see an empty list when they click the arrow next to the combo box. In the Combo Box Properties dialog box, you can type the entries yourself or configure the combo box to retrieve entries from a database or other data source.
Related controls
Microsoft Office InfoPath includes other controls that are similar to combo boxes but that serve different purposes. To decide which of these controls works best on your form template, refer to the following list:
List box Like a combo box, a list box allows users to select values in a list. However, users cannot add their own values to a list box. Also, a list box displays all of the items in the list, whereas the items in a combo box are hidden until the user clicks the control. If you plan to offer the user many choices in your control, list boxes may take up too much space on your form template. In this scenario, a drop-down list box or combo box may be a better choice.
Drop-down list box Like a combo box, a drop-down list box enables users to select a value in a list that is hidden on the form by default. However, with a drop-down list box, users cannot add items to the list as they can with a combo box.
Multiple-selection list box If you want users to be able to choose more than one item in a list, you can use a multiple-selection list box. Multiple-selection list boxes look like two or more check boxes inside a scrollable list. Like a combo box, a multiple-selection list box enables users to add their own item to the list.
Option buttons Like a combo box, a group of option buttons enables users to select from a list of mutually exclusive choices. However, with option buttons, users click a small circle to make a choice instead of clicking an item in a list box.
The user experience
Combo boxes are similar in appearance to drop-down list boxes, but they allow users to add their own item to the list, if necessary. If you manually typed your own list items in the Combo Box Properties dialog box when creating a combo box, InfoPath displays the text "Select or type..." as the default entry in the combo box. This lets users know that either action is acceptable. If the list items in the combo box display values from elsewhere on the form or from a secondary data source, the "Select or type..." text is omitted.
When users first open a form, the list items in a combo box are hidden. To open the list, users click an arrow on the right side of the combo box. They can then click an item to select it.
If users don't see an appropriate list item, they can click in the box and type their own value.
Compatibility considerations
When you design a form template in InfoPath, you can choose to design a browser-compatible form template. When you design a browser-compatible form template, combo box controls are unavailable in the Controls task pane because they cannot be displayed in a Web browser.
Insert a combo box
The procedure for inserting a combo box differs slightly depending on whether you are designing a new, blank form template or basing the design of your form template on a database or other external data source.
The following illustration shows how a combo box looks when it is selected in design mode.
Controls can be bound or unbound. When a control is bound, it is connected to a field or group in the data source so that data entered into the control is saved in the underlying form (.xml) file. When a control is unbound, it is not connected to a field or group, and data entered into the control is not saved. When you select or move your pointer over a control, text and a binding icon appear in the upper-right corner of the control. The text indicates the group or field to which the control is bound in the data source. The icon indicates whether the control is correctly bound to that group or field. When the binding is correct, a green icon appears. If there's something wrong with the binding, you'll see a blue or red icon instead.
The data source for the form template consists of fields and groups that appear in a hierarchical view in the Data Source task pane. Combo boxes are always bound to fields. In the following example, the Category combo box on the form template is bound to the category field in the Data Source task pane.
When you design a new, blank form template, the Automatically create data source check box in the Controls task pane is selected by default. This enables InfoPath to automatically create fields and groups in the data source as you add controls to the form template. These fields and groups are represented by folder and file icons in the Data Source task pane.
If you base the design of your form template on an existing Extensible Markup Language (XML) file, database, or Web service, InfoPath derives the fields and groups in the Data Source task pane from that existing data source.
Insert a combo box
-
On the form template, place the cursor where you want to insert the control.
-
If the Controls task pane is not visible, click More Controls on the Insert menu, or press ALT+I, C.
-
In the Controls task pane, do one of the following:
-
To automatically create a field in the data source that is bound to the list box, select the Automatically create data source check box.
-
To bind the list box to an existing field, clear the Automatically create data source check box.
Note: If the check box is unavailable, the data source is locked. For example, if you base the design of your form template on an XML Schema, you may not be able to add new fields or groups to the data source in InfoPath. This restriction helps to prevent you from inadvertently making changes to the schema that may render it invalid.
-
-
Under Insert controls, click Combo Box.
-
If you cleared the Automatically create data source check box in step 3, select a field in the Combo Box Binding dialog box to which you want to bind the list box.
-
To add a label to the control, type text above or to the left of the control, followed by a colon (:).
-
To specify the values that you want to use as the entries in the list, double-click the combo box.
-
Click the Data tab.
-
Do one of the following to populate the combo box:
Type the list box values yourself
This option is useful when you have a predetermined, limited set of values, and you don't expect those values to change in the future. If the values do happen to change, you must publish an updated version of your form template so that users can see and use the latest list entries.
-
Click Add.
-
In the Value box, type the text that you want to store if a user selects this entry.
-
In the Display name box, type the text that you want to display for this entry, and then click OK.
-
Repeat steps 1 through 3 for each entry that you want to add to the list box.
-
To test your changes, click Preview on the Standard toolbar, or press CTRL+SHIFT+B.
Use values from another part of the form
This option is useful when you want the values in your list to change, depending on other values that the users enter into their form.
-
Under List box entries, click Look up values in the form's data source.
The entries in the list box must be associated with a particular repeating group or repeating field on your form template.
-
Click Select XPath next to the Entries box, and then in the Select a Field or Group dialog box, click the repeating field or repeating group that contains the fields that will provide the values for the list box, and then click OK.
-
Click Select XPath next to the Value box, click the field that contains the possible values for the items in the list box, and then click OK. One of these values will be saved in the underlying XML when a user clicks an item in the list box.
-
Click Select XPath next to the Display name box, click the field that contains the values that are displayed in the list box, and then click OK.
Tip: To prevent display name values from appearing multiple times in the list box, select the Show only entries with unique display names check box.
Use values from a database, Web service, XML document, or SharePoint site
This option is useful when you want the values in a list box to be up-to-date or refreshed regularly. The values are typically stored in a database or other external data source and are retrieved every time the form is opened.
-
Click Look up values from an external data source.
-
Do one of the following:
-
If you already added a data connection, click it in the Data Connection box.
-
To add a new data connection, click Add, and then follow the instructions in the Data Connection Wizard.
The entries in the list box must be associated with a particular repeating field or repeating group.
-
-
Click Select XPath next to the Entries box, and then in the Select a Field or Group dialog box, click the group or field that contains the fields that will provide the values for the list box, and then click OK.
-
Click Select XPath next to the Value box, click the field that contains the possible values for the items in the list box, and then click OK. One of these values will be saved in the underlying XML when a user clicks an item in the list box.
-
Click Select XPath next to the Display name box, click the field that contains the values that are displayed in the list box, and then click OK.
Tip: To prevent display name values from appearing multiple times in the list box, select the Show only entries with unique display names check box.
-
Layout tips
Use the following tips to help you refine the appearance, size, and other aspects of a combo box control:
-
Consider widening the combo box so that it is a few spaces larger than the average width of the items in the list. That way, the list items aren't partially hidden.
-
To change the width of several combo boxes at once, select the combo boxes whose size you want to change, press ALT+ENTER, click the Size tab, and then in the Width box, type a new number.
-
To change the background color for several combo boxes at once, select the combo boxes that you want to change. On the Format menu, click Borders and Shading, and then make the necessary adjustments on the Shading tab.
-
To customize the font that appears in a combo box, use the Font and Font Size boxes on the Formatting toolbar. To change the font and font size for all of the combo boxes on your form template at once, click the combo box that contains the formatting that you want, and then on the Format menu, click Apply Font to All Combo Box Controls.
-
If you want to adjust the spacing between a combo box and the objects that surround it on the form template, you can adjust the margin settings in the Combo Box Properties dialog box (Size tab). Using margins to increase spacing offers a finer degree of control than using paragraph breaks to increase spacing.
No comments:
Post a Comment