- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我要实现的目标:
使用加载器/微调器渲染页面
如果 service-worker.js
已注册并处于事件状态,则检查更新
updatefound
并且安装了新版本,则重新加载页面service-worker.js
updatefound
时,意味着安装了新的,移除 loader我正在使用 sw-precache
模块来生成 service-worker.js
和以下注册码:
window.addEventListener('load', function() {
// show loader
addLoader();
navigator.serviceWorker.register('service-worker.js')
.then(function(swRegistration) {
// react to changes in `service-worker.js`
swRegistration.onupdatefound = function() {
var installingWorker = swRegistration.installing;
installingWorker.onstatechange = function() {
if(installingWorker.state === 'installed' && navigator.serviceWorker.controller){
// updated content installed
window.location.reload();
} else if (installingWorker.state === 'installed'){
// new sw registered and content cached
removeLoader();
}
};
}
if(swRegistration.active){
// here I know that `service-worker.js` was already installed
// but not sure it there are changes
// If there are no changes it is the last thing I can check
// AFAIK no events are fired afterwards
}
})
.catch(function(e) {
console.error('Error during service worker registration:', e);
});
});
看完spec很明显,没有像 updatenotfound
这样的处理程序。看起来 serviceWorker.register
检查 service-worker.js
是否通过运行 get-newest-worker-algorithm 在内部更改,但我看不到通过公共(public) api 公开的类似方法。
我认为我的选择是:
onupdatefound
service-worker.js
代码触发自定义事件
还有其他建议吗?
编辑:
我想出了一些代码,通过在 SW 注册和 SW 客户端之间使用
postMessage()
解决了这个问题(如@pate 所建议的那样)
下面的demo试图通过postMessage
实现SW客户端和SW注册之间的校验,但是失败了,因为SW代码已经被缓存了DEMO
编辑:
所以现在看来我无法实现我想要的,因为:
onupdatefound
,没有其他任何东西会通知 SW 的更改activation
旧版 SW 在 onupdatefound
激活
后不会触发任何东西update()
不成熟,不断变化,从 Chrome 46 开始,如果操作成功完成或没有更新,update() 将返回一个解析为“undefined”的 promise
最佳答案
Fabio 提供的另一个答案无效。 Service Worker 脚本无权访问 DOM。不可能从 DOM 中删除任何东西,或者,例如,从 Service Worker 中操作任何正在处理 DOM 元素的数据。该脚本单独运行,没有共享状态。
不过,您可以做的是在实际运行页面的 JS 和 Service Worker 之间发送消息。我不确定这是否是执行 OP 所要求的最佳方法,但可用于实现它。
我自己将软件版本号保存在软件内部的一个变量中。然后我的 SW 将该版本号发布到页面,页面将其存储到浏览器的 localStorage 中。下次加载页面时,SW 将其当前版本号发布到页面上,onmessage 处理程序将其与当前存储的版本号进行比较。如果它们不相同,则 SW 已更新为包含在消息中的某个版本号。之后,我更新了版本号的 localStorage 副本并完成了这个和那个。
此流程也可以通过其他方式完成:从页面向 SW 发送一条消息,让 SW 回复一些内容,然后采取相应的行动。
我希望我能够清楚地解释我的想法:)
关于javascript - 如何: ServiceWorker check if ready to update,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45759595/
这个问题在这里已经有了答案: What's the proper value for a checked attribute of an HTML checkbox? (10 个答案) 关闭 8 年
我使用这个制作了自定义复选框: enter link description here 也可在 stackoverflow 上获得:enter link description here 但我正在尝试
我需要使用 CSS“checkbox-hack”来实现滑动菜单指示器效果,我唯一的方法是通过 JavaScript 附加输入元素。我被迫通过在线工具 MonoSolutions 执行此操作,并且我受到
此代码运行良好,但缺少一些我需要的东西。基本上,如果输入有一个 checked="checked" 属性,它应该使其他两个元素保持禁用状态。如果未选中,则元素已启用。 这是我在 jsFiddle 上的
当我的人 checkout 文件时,我希望他们将其锁定,以便其他人也无法进行更改,我从这篇文章中看到:http://msdn.microsoft.com/en-us/library/jj155783.
请告诉我这些函数的作用。 最佳答案 这些是基于框架的、与语言无关的方法,用于在 .NET 中定义代码契约。虽然某些语言(如 spec# 和 Delphi Prism)对代码契约具有一流的语言支持,但这
假设以下场景:您有 2 个单选按钮,它们具有相同的名称,并且都被选中(我知道这是无效的): 为什么下面两个选择器的行为不同? $('.input:checked').size(); // retu
我正在尝试收听广播。以下均不起作用: [编辑] $('selector').attr('checked','checked'); $('selector').attr('checked',true);
我实际上在努力理解此类型错误。 任何人都知道我如何更正代码?谢谢 CheckIn checkin1 = new CheckIn(location1, dt); CheckInMonths checkI
我有这段代码,但不起作用。 .on("click","span.name", function selectThisName(e) { if (e.altKey) {
我现在是 Espresso 的新手,我遇到了这个异常: android.support.test.espresso.AmbiguousViewMatcherException: 'with id: a
我已经创建了一个基本的 2 单选按钮表单,如下面的示例所示。 观察浏览器渲染,我们看到元素 1 被选中。我们检查元素 1 和元素 2。 当我点击元素 2 时,我希望元素 1 的 checked=che
我在查找以下 jquery/checkbox 行为的原因时遇到问题。 $( this.obj + ' table.sgrid-content > thead > tr > th > input.sel
以下逻辑应用在上午 10 点触发并运行 SQL Server 查询。从图片中可以看出,结果集是空的。 条件检查检查查询的结果集是否为空。 (第二张图) 这仍然如何转化为 True?结果显然是空的。 最
我想知道哪种操作更快: int c = version1.compareTo(version2); 这个 if (c == 1) 或者这个 if (c > 0) 符号比较是否只使用一位检查,而相等比较
我有一个包含大约 100 个问题的表单,每个问题都有一个单选按钮和一些复选框,因此我需要用户能够保存表单并在以后加载它。我还需要检查用户在此 session 中更改了哪些。 本题解决问题:How ca
我正在编写一个小程序,需要用户决定一些 bool 值。我已经制作了复选框来处理这一部分,但问题是每次我选中或取消选中一个复选框时,所有其他复选框都会跟随。 我在网上搜索过,但我找到的唯一解释( pyt
我有以下代码片段(我使用的是 jQuery 1.4.2): $.post('/Ads/GetAdStatsRow/', { 'ad_id': id }, function(result) {
我的代码发生了一些奇怪的事情。我有两个按钮,其中一个带有 .add 和 .remove 类,有一个复选框会根据按下哪个按钮而打开和关闭,因此如果您使用删除按钮删除,则选中的复选框将被选中,否则复选框将
我陷入了一种情况,我必须通过“选中”工具栏中的复选框来“选中”列表中存在的所有复选框。 这是创建复选框列表的代码:- itemTpl: 'checked="checked" /> {groupName
我是一名优秀的程序员,十分优秀!