javascript-检查Chrome / Chromium插件中的Internet连接;加载的图像已缓存
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript-检查Chrome / Chromium插件中的Internet连接;加载的图像已缓存,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1302字,纯文字阅读大概需要2分钟。
内容图文
我正在尝试检查Chrome插件中是否存在互联网连接.尽管有可用的API调用建议进行检查,但从理论上讲,它仅检查是否可以连接互联网.
为了获得此信息,我尝试加载图像
checkConnection() {
var newImg = new Image;
newImg.src = url;
newImg.onload = function() { ... }
newImg.onerror = function() { ... }
}
我确实使用Image对象来避免在JavaScript中使用get请求时发生的Same-Origin-Policies的所有这些问题(我从插件中使用代码,因此没有与我的代码具有相同来源的地址: /).原则上,我的上述代码有效.我有一个setTimeout每隔一次调用checkConnection.但是,一次成功加载映像(每次插件重新加载)后,该映像将存储在缓存中,并在连接失败时从那里加载.
您是否有办法解决这个问题?还是您知道一种聪明的方法,可以通过Chrome插件检查互联网连接,而无需设置可能会容忍我的请求来源的服务器?
解决方法:
您知道3个选项…
检查互联网连接
快速搜寻之后,我发现navigator.onLine.您似乎可以用它来检查网际网路连线,但并不总是完全正确.
停止图像缓存
如果您可以控制托管映像的域,则可以设置标头,告诉浏览器不要缓存映像.
Cache-Control: no-cache, must-revalidate // HTTP/1.1
Expires: Sat, 26 Jul 1997 05:00:00 GMT // Date in the past
如果您没有域的控制权,则在加载图像时,请尝试将GET变量附加到具有随机数或当前时间戳的URL上.
例如.
https://example.com/image.png?time=1496222683
https://example.com/image.png?time=1496223323
https://example.com/image.png?time=1496222313
这可能会诱使浏览器认为您正在请求新资源.
内容总结
以上是互联网集市为您收集整理的javascript-检查Chrome / Chromium插件中的Internet连接;加载的图像已缓存全部内容,希望文章能够帮你解决javascript-检查Chrome / Chromium插件中的Internet连接;加载的图像已缓存所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。