- 对于QQ这类实时通讯软件, 设置系统通知是非常常见的功能, 对于办公用的电子邮件服务, 收到新邮件进行通知也是非常必要的
- Electron适用于创建跨平台应用, 对于系统通知这类常见需求, 也提供了非常好用的api
- 用户收到系统通知后, 往往会通过点击系统通知, 打开与通知相对应的界面, 这个功能往往也是必须的
需求: 我们需要创建一个动漫更新的系统通知, 当用户点击系统的通知, 就会打开相应的界面播放动漫, 这是一个Electron功能演示的文章, 所以并不涉及如何通过网络监听各大平台的动漫更新情况(当然实现的思路也是有的, 用一个爬虫程序, 定时去爬各个平台的动漫的标题目录的变化, 如果有更新, 则通过回调函数, 发出系统通知)
效果展示
源码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Electron发送系统通知</title>
</head>
<body>
<style>
button {
color: #ffffff;
background-color: #44A1F8;
font-size: 20px;
outline: none;
}
</style>
<button id="btn1">点击我,可以触发系统通知</button>
<script>
const path = require('path');
const {shell} = require('electron')
document.getElementById("btn1").onclick = function(){
let option = {
title: "你订阅的《海贼王》更新了",
body: "《海贼王》已更新至第852集 激斗开幕 路飞VS卡塔库栗",
icon: "../static/hhw.ico",
href: 'https://www.iqiyi.com/v_19rqz6uit0.html'
};
// 创建通知并保存
let hhwNotication = new window.Notification(option.title, option);
// 当通知被点击时, 用默认浏览器打开链接
hhwNotication.onclick= function(){
shell.openExternal(option.href)
}
}
</script>
</body>
</html>
系统通知的图标最好是ico格式图片, 但简书不支持上传ico格式的图片, 我们可以通过http://www.bitbug.net/ 制作, 简单快捷, 下面我在源码中使用的图片资源
../static/hhw.ico
, 感兴趣的可以用http://www.bitbug.net/ 自己制作成ico格式的图片(自己动手, 丰衣足食)
小结:
Electron对系统通知这种常见功能封装的很好, 善用系统通知功能, 能让我们的程序更好用
用Electron创建跨平台应用是一个连载, 如果阅读本篇有困难,可以补一下前两弹的内容
用Electron创建跨平台应用(第一弹)
用Electron创建跨平台应用(第二弹)开启多窗口