我正在尝试使用带有菜单项的AngularJS创建一个Electron应用程序。我可以在主电子javascript文件中定义这个菜单项,如下所示:
var Menu = require('menu');
var menu = new Menu();
var tpl = [
{
label: 'Actions',
submenu: [
{
label: 'Xxxx',
click: function() { /* I want to change the state here */ }
}
]
}
];
menu = Menu.buildFromTemplate( tpl );
Menu.setApplicationMenu(menu);
但是当用户点击子菜单时,我不知道如何改变AngularJS的状态(我正在使用ui-router)。
此外,我正在尝试根据应用程序中的控制器(或状态)更改菜单项。我知道我不能在Angular代码中做一个require('menu'),所以如何更改控制器中的菜单项呢?
由于
答案 0 :(得分:6)
我要回答我自己的问题,我找到了解决方案。
使用remote
模块,我可以将Web进程与主进程通信,并调用主进程对象的方法。因此,在AngularJS应用程序的主控制器中,我可以这样做:
.controller('AppController', function ($scope, $rootScope, $state, $http, $location) {
$rootScope.remote = require('remote');
var Menu = $rootScope.remote.require('menu');
var App = $rootScope.remote.require('app');
var menu = new Menu();
var tpl = [
{
label: 'Actions',
submenu: [
{
label: 'GoPage',
click: function() {
$state.go('samepage');
}
},
{
label: 'Quit',
click: function() { App.quit(); },
accelerator: 'Command+Q'
}
]
}
];
menu = Menu.buildFromTemplate( tpl );
Menu.setApplicationMenu(menu);
})
通过这种方式,我可以根据菜单项点击调用AngularJS函数,并根据应用程序中的控制器更改菜单项。