electron-vue 图标
提示:图标包括:启动项目时桌面主题图标,窗口左上角图标,菜单栏图标,系统托盘图标,打包安装图标、开始菜单图标、快捷方式图标等。
1. 启动项目默认图标与窗口左上角图标
这两个图标均由 mainWindow 的 icon 属性决定: 代码如下(示例):
mainWindow = new BrowserWindow({
height: 620,
width: 400,
useContentSize: true,
icon: path.join(__static,"./zero.ico"),
webPreferences:{
nodeIntegration:true,
contextIsolation: false,
webSecurity: false,
},
})
效果如下: data:image/s3,"s3://crabby-images/832d4/832d460b19c57f6dea259300ff99ca4dcee4571c" alt="在这里插入图片描述" 另外,窗口左上角 标题 也可以自定义,修改位置如下(注意:修改完成后需重新启动运行代码才可生效): data:image/s3,"s3://crabby-images/9b527/9b527d5fa6178ce43e3de88b6aa6592a47b10868" alt="在这里插入图片描述"
2. 菜单栏图标
可在菜单文字表达前添加图标
代码如下(示例):
{
label: "显示主窗口",
icon: path.join(__static,"./logo.png"),
click: function() {
mainWindow.show();
} //打开相应页面
},
{//打开相应页面
label: "检查更新",
type:'checkbox',
checked: true,
click: function() { }
},
效果如下: data:image/s3,"s3://crabby-images/dad09/dad09f2c844095c1bb22d3d2bab3f470d2102c46" alt="在这里插入图片描述"
3. 系统托盘图标
系统托盘图标可自定义设置:
代码如下(示例):
let iconPath = path.join(__static, "./zero.ico");
let appTray = new Tray(iconPath);
效果如下 data:image/s3,"s3://crabby-images/327dd/327ddacb5cfb78bc19d646bbc0987cdab435bff5" alt="在这里插入图片描述"
4. 打包安装包图标
在 package.json 中配置:
代码如下(示例):
"win": {
"icon": "build/icons/zero.ico",
"artifactName": "${productName}_setup_${version}.${ext}",
"target": [
{
"target": "nsis",
"arch": [
"x64"
]
}
]
},
效果如下: data:image/s3,"s3://crabby-images/d29b1/d29b19482ecc8b3068aa4665a1e5ac2023ee8b13" alt="在这里插入图片描述"
5. 开始菜单图标和快捷方式图标
在 package.json 中配置 : 其中 createDesktopShortcut表示创建快捷方式图标 createStartMenuShortcut 表示开始菜单图标
代码如下(示例):
"nsis": {
"oneClick": false,
"allowElevation": true,
"allowToChangeInstallationDirectory": true,
"installerIcon": "./build/icons/zero.ico",
"uninstallerIcon": "./build/icons/zero.ico",
"installerHeaderIcon": "./build/icons/zero.ico",
"createDesktopShortcut": true,
"createStartMenuShortcut": true,
"shortcutName": "xxxx"
}
6、dialog 弹框图标
ipcMain.on('logout',(e)=>{
dialog.showMessageBox({
type: 'info',
noLink:true, // windows 下的传统样式
title: '提示信息',
icon:path.join(__static,"./zero.ico"),
defaultId: 0,
message:"确定要退出登录吗?",
buttons:['确定','取消']
},(index) => {
if(index === 1){
// 什么都不做
e.preventDefault(); // 阻止默认行为
}else{
mainWindow.loadURL(winURL)
mainWindow.setSize(400,400);
}
});
})
实现效果: data:image/s3,"s3://crabby-images/fddd9/fddd9e539684f624d0eeb3dd3efd8474040faf84" alt="在这里插入图片描述"
总结
以上是我个人项目中使用到的图标,欢迎大家补充
|