一个输入字段,可让用户从一组预定义选项中进行选择。
仅支持对 Selection
和 Selection
菜单进行表单提交验证。如果 Action.setAllWidgetsAreRequired(allWidgetsAreRequired)
设置为 true
或通过 Action.addRequiredWidget(requiredWidget)
指定此微件,除非选择某个值,否则系统会阻止提交操作。
适用于 Google Workspace 插件和 Google Chat 应用。
const checkboxGroup = CardService.newSelectionInput() .setType(CardService.SelectionInputType.CHECK_BOX) .setTitle('A group of checkboxes. Multiple selections are allowed.') .setFieldName('checkbox_field') .addItem('checkbox one title', 'checkbox_one_value', false) .addItem('checkbox two title', 'checkbox_two_value', true) .addItem('checkbox three title', 'checkbox_three_value', true) .setOnChangeAction( CardService.newAction().setFunctionName('handleCheckboxChange'), ); const radioGroup = CardService.newSelectionInput() .setType(CardService.SelectionInputType.RADIO_BUTTON) .setTitle( 'A group of radio buttons. Only a single selection is allowed.') .setFieldName('checkbox_field') .addItem('radio button one title', 'radio_one_value', true) .addItem('radio button two title', 'radio_two_value', false) .addItem('radio button three title', 'radio_three_value', false); const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', ) .setMultiSelectMaxSelectedItems(3) .setMultiSelectMinQueryLength(1);
方法
方法 | 返回类型 | 简介 |
---|---|---|
add | Selection | 添加可供选择的新项。 |
add | Selection | 为多选菜单添加可供选择的新项。 |
set | Selection | 设置外部数据源,例如关系型数据库。 |
set | Selection | 在发生界面互动时生成的事件对象中设置用于标识此选择输入的键。 |
set | Selection | 设置用户可选择的项数上限。 |
set | Selection | 设置用户在应用查询自动补全功能并在卡片上显示建议内容之前输入的文本字符数。 |
set | Selection | 设置在选择输入发生变化时执行的 Action 。 |
set | Selection | 设置 Google Workspace 中的数据源。 |
set | Selection | 设置要在输入字段前面显示的标题。 |
set | Selection | 设置此输入的类型。 |
详细文档
add Item(text, value, selected)
添加可供选择的新项。
参数
名称 | 类型 | 说明 |
---|---|---|
text | Object | 要显示的此项的文本。非字符串基元参数会自动转换为字符串。 |
value | Object | 通过回调发送的表单输入值。非字符串基元参数会自动转换为字符串。 |
selected | Boolean | 相应项是否默认处于选中状态。如果选择输入仅接受一个值(例如单选按钮或下拉菜单),请仅为一个项设置此字段。 |
返回
Selection
- 此对象,用于链式调用。
add Multi Select Item(text, value, selected, startIconUri, bottomText)
为多选菜单添加可供选择的新项。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', );
参数
名称 | 类型 | 说明 |
---|---|---|
text | Object | 要显示的此项的文本。非字符串基元参数会自动转换为字符串。 |
value | Object | 通过回调发送的表单输入值。非字符串基元参数会自动转换为字符串。 |
selected | Boolean | 相应项是否默认处于选中状态。如果选择输入仅接受一个值(例如单选按钮或下拉菜单),请仅为一个项设置此字段。 |
start | Object | 对于多选菜单,是显示在项文本字段旁边的图标的网址。支持 PNG 和 JPEG 文件。 |
bottom | Object | 对于多选菜单,是显示在项文本字段下方的文本说明或标签。 |
返回
Selection
- 此对象,用于链式调用。
set External Data Source(action)
设置外部数据源,例如关系型数据库。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('contacts') .setTitle('Selected contacts') .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .setMultiSelectMaxSelectedItems(5) .setMultiSelectMinQueryLength(2) .setExternalDataSource( CardService.newAction().setFunctionName('getContacts'), );
参数
名称 | 类型 | 说明 |
---|---|---|
action | Action | 外部数据源。 |
返回
Selection
- 此对象,用于链式调用。
set Field Name(fieldName)
在发生界面互动时生成的事件对象中设置用于标识此选择输入的键。对用户不可见。必填,必须是唯一的。
参数
名称 | 类型 | 说明 |
---|---|---|
field | String | 要分配给此输入的名称。 |
返回
Selection
- 此对象,用于链式调用。
set Multi Select Max Selected Items(maxSelectedItems)
设置用户可选择的项数上限。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .setMultiSelectMaxSelectedItems(3) .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', );
参数
名称 | 类型 | 说明 |
---|---|---|
max | Integer | 项的数量上限。 |
返回
Selection
- 此对象,用于链式调用。
set Multi Select Min Query Length(queryLength)
设置用户在应用查询自动补全功能并在卡片上显示建议内容之前输入的文本字符数。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('multiselect') .setTitle('A multi select input example.') .setMultiSelectMinQueryLength(1) .addMultiSelectItem( 'Contact 1', 'contact-1', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact one description', ) .addMultiSelectItem( 'Contact 2', 'contact-2', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact two description', ) .addMultiSelectItem( 'Contact 3', 'contact-3', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact three description', ) .addMultiSelectItem( 'Contact 4', 'contact-4', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact four description', ) .addMultiSelectItem( 'Contact 5', 'contact-5', false, 'https://www.gstatic.com/images/branding/product/2x/contacts_48dp.png', 'Contact five description', );
参数
名称 | 类型 | 说明 |
---|---|---|
query | Integer | 文本字符数。 |
返回
Selection
- 此对象,用于链式调用。
set On Change Action(action)
set Platform Data Source(platformDataSource)
设置 Google Workspace 中的数据源。用于填充多选菜单中的项。
const multiSelect = CardService.newSelectionInput() .setType(CardService.SelectionInputType.MULTI_SELECT) .setFieldName('contacts') .setTitle('Selected contacts') .setPlatformDataSource( CardService.newPlatformDataSource().setCommonDataSource( CardService.CommonDataSource.USER, ), );
参数
名称 | 类型 | 说明 |
---|---|---|
platform | Platform | 数据源。 |
返回
Selection
- 此对象,用于链式调用。