我是 Typescript 的新手,如果这是一个简单的问题,我深表歉意。
我正在尝试构建一个在 Electron (http://electron.atom.io/) 上运行的应用程序。我已经使用类型( https://github.com/typings/typings )添加了类型声明 - 使用 env: Electron 类型。
这似乎很好。我现在可以根据需要从类型中导入声明。
但是,我正在尝试为我的应用程序创建一个应用程序菜单。我想使用的方法是创建一个"template"对象并使用 Menu.buildFromTemplate 方法( http://electron.atom.io/docs/api/menu/ )。
我面临的问题是 Menu.buildFromTemplate 的类型定义指定:
static buildFromTemplate(template: MenuItemOptions[]): Menu;
并且MenuItemOptions接口(interface)没有在定义文件中导出。
我尝试了两件事:
const template = [
{
label: 'Edit',
submenu: [
{
label: 'Undo',
accelerator: 'CmdOrCtrl+Z',
role: 'undo'
},
{
label: 'Redo',
accelerator: 'Shift+CmdOrCtrl+Z',
role: 'redo'
}
]
}
];
const menu = Menu.buildFromTemplate(template);
这给了我一个错误:“类型的参数'{标签:字符串;子菜单:{标签:字符串;加速器:字符串;角色:字符串;}[];}[]'不可分配给'MenuItemOptions []类型的参数’。”
由此,我认为我需要将模板转换为 MenuItemOptions。但是,我无法将 MenuItemOptions 添加到导入中,因为它没有在定义中导出。
这是定义中的错误吗? MenuItemOptions 是否也应该被导出?或者,我做错了什么。
如果需要,我可以提供完整的来源。
最佳答案
显式输入 template
为我工作
const template : Electron.MenuItemOptions[] = [
{
label: 'Edit',
submenu: [
{
label: 'Undo',
accelerator: 'CmdOrCtrl+Z',
role: 'undo'
},
{
label: 'Redo',
accelerator: 'Shift+CmdOrCtrl+Z',
role: 'redo'
}
]
}
];
const menu = Menu.buildFromTemplate(template);
似乎是因为
role
属性注册为类型 string
与类型 '"undo" | "redo" | "cut" | "copy" | "paste" | "selectall" | "minimize" | "close" | "about" | "hide...'
不兼容
关于menu - 非导出接口(interface)的类型断言,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37620226/