当前位置: 首页 > 文档资料 > Tabris 中文文档 >

ActionSheet(操作列表)

优质
小牛编辑
136浏览
2023-12-01

继承自Popup

提供操作选择的弹出框。关闭时自动销毁。

通过“const {ActionSheet} = require('tabris');”引入该类

属性

actions

Type: *{title: string, image?: Image, style?: ‘default’‘cancel’‘destructive’}[]*

描述可供选择的操作的对象数组。每个操作必须要有一个标题,也可以包含一个图片。canceldestructive类型的操作会被特殊显示。

message

Type: string

可用操作的描述信息。

title

Type: string

操作列表的标题。

Events

actionsChanged

actions属性变化时触发。

Event Parameters

  • target: this 事件触发的控件。

  • value: {title: string, image?: Image, style?: ‘default’|’cancel’|’destructive’}[] actions属性被设置的新的值。

close

操作列表被关闭时触发。

messageChanged

message属性变化时触发。

Event Parameters

  • target: this 事件触发的控件。

  • value: string message属性被设置的新的值。

select

当一个操作被选中时触发。

Event Parameters

  • target: this 事件触发的控件。

  • index: number 被选中的操作的索引。

titleChanged

title属性改变时触发。

Event Parameters

  • target: this 事件触发的控件。

  • value: string title属性被设置的新的值。

示例

const {ActionSheet, TextView, Button, ui} = require('tabris');

new Button({
  left: 16, right: 16, top: 16,
  text: 'Show ActionSheet'
}).on({select: showActionSheet})
  .appendTo(ui.contentView);

let selectionTextView = new TextView({
  left: 16, right: 16, top: ['prev()', 16],
  alignment: 'center'
}).appendTo(ui.contentView);

function showActionSheet() {
  new ActionSheet({
    title: 'Actions',
    message: 'Select any of the actions below to proceed.',
    actions: [
      {title: 'Search', image: {src: 'images/search-black-24dp@3x.png', scale: 3}},
      {title: 'Share', image: {src: 'images/share-black-24dp@3x.png', scale: 3}},
      {title: 'Settings', image: {src: 'images/settings-black-24dp@3x.png', scale: 3}},
      {title: 'Delete', image: {src: 'images/delete-black-24dp@3x.png', scale: 3}, style: 'destructive'},
      {title: 'Cancel', image: {src: 'images/close-black-24dp@3x.png', scale: 3}, style: 'cancel'},
    ]
  }).on({
    select: ({target: actionSheet, index}) => selectionTextView.text = `"${actionSheet.actions[index].title}" selected`,
    close: () => console.log('ActionSheet closed')
  }).open();
}