我有一种情况,我需要打开和关闭在 Electron 窗口内的webview中加载的网页的通知。为此,我在Web View 中注入(inject)了一个预加载文件,该文件将覆盖这样的Notification对象。
window.oldNotification = window.Notification;
window.Notification = function() {
let notificationEnabled = localStorage.getItem('notification-permissions') === 'true';
if (notificationEnabled) {
new window.oldNotification(...arguments);
}
};
我通过更改本地存储变量来启用和禁用通知。
问题是我要控制的网页正在使用
Notification.permission
方法(refer this)。现在,我的新Notification对象没有权限属性。我无法以可以更新其构造函数的方式覆盖Notification对象,以便可以禁用通知并具有原始Notification对象的其他属性。有没有办法做到这一点,或者根本不可能吗?任何帮助或建议都是绝对欢迎的。
最佳答案
您可以轻松模拟Notification API
window.Notification = function() {
const notificationEnabled = Notification.permission === 'granted';
return notificationEnabled ? new window.oldNotification(...arguments) : {};
};
Object.defineProperty(Notification, 'permission', {
get() {
return localStorage.getItem('notification-permissions') === 'true' ? 'granted' : 'denied';
}
});
Notification.requestPermission = (callback) => {
if (typeof callback === 'function') {
callback(Notification.permission);
}
return Promise.resolve(Notification.permission);
};
关于javascript - 如何覆盖JavaScript Web API通知对象,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/53390156/