js操作serviceWorker缓存静态文件

serviceWorker的作用就是用来做离线应用的,在手机端程序中用的较多

  1. 先看下效果

  2. index.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
    .box{
    background-image: url("./img/alt.png");
    width: 100px;
    height: 100px;
    }
    </style>
    </head>
    <body>
    <!-- <img src="./img/alt.png" alt=""> -->
    <div class="box"></div>
    <script>
    if(navigator.serviceWorker) {
    navigator.serviceWorker.register('./sw.js').then(function(res){
    console.log(res.scope + "->" + "service worker注册成功");
    }).catch(function(err){
    console.log(err);
    })
    }else{
    alert("你的浏览器不支持serviceWorker");
    }
    </script>
    </body>
    </html>
  3. sw.js

    var version = "v1::"; // 设置版本号
    
    self.addEventListener("install", function (event) { // serviceworker第一次加载的时候调用,可以在此时缓存静态资源
    event.waitUntil(
    // caches帮助我们缓存资源
    caches
    .open(version + 'fundamentals')
    .then(function (cache) {
    // 将列出的文件缓存起来
    return cache.addAll([
    '/',
    '/img/alt.png'
    ]);
    })
    .then(function () {
    console.log('缓存完毕');
    })
    );
    }); self.addEventListener('activate', function (event) { // install方法调用完毕后就调用此方法,主要用来删除过期的缓存 event.waitUntil(
    caches
    // keys方法用来获取缓存版本号
    .keys()
    .then(function (keys) {
    // 下面的方法用来删除不是以version开头的缓存版本
    return Promise.all(
    keys
    .filter(function (key) {
    return !key.startsWith(version);
    })
    .map(function (key) {
    return caches.delete(key);
    })
    );
    })
    .then(function () {
    console.log('WORKER: 激活完毕.');
    })
    );
    }) self.addEventListener('fetch', function (event) { // 请求外部资源时调用 // 只捕获get请求
    if (event.request.method !== 'GET') {
    // 只让get请求去缓存中查找
    console.log('WORKER: 被拦截的api.', event.request.method, event.request.url);
    return;
    } // 让get请求取缓存中查找资源
    event.respondWith(
    caches
    .match(event.request)
    .then(function (cached) {
    // 将缓存中的资源立即返回,并且同时去服务器下载最新的资源存到缓存中
    var networked = fetch(event.request)
    .then(fetchedFromNetwork, unableToResolve)
    .catch(unableToResolve); // 通过caches.match这个方法,如果缓存中有资源,直接就返回了,如果没有转向网络
    console.log('WORKER: fetch event', cached ? '(cached)' : '(network)', event.request.url);
    return cached || networked; function fetchedFromNetwork(response) {
    // 从网络中加载资源
    var cacheCopy = response.clone();
    console.log('WORKER: 从网络中拉取的资源地址.', event.request.url);
    caches
    // 存储资源
    .open(version + 'pages')
    .then(function add(cache) {
    cache.put(event.request, cacheCopy);
    })
    .then(function () {
    console.log('WORKER: 从网络中拉取的资源已经缓存', event.request.url);
    });
    return response;
    } // 既不能从网络中获取资源又不能从缓存中获取,就会调用此方法
    function unableToResolve() {
    console.log('WORKER: 获取资源失败.');
    return new Response('<h1>Service Unavailable</h1>', {
    status: 503,
    statusText: 'Service Unavailable',
    headers: new Headers({
    'Content-Type': 'text/html'
    })
    });
    }
    })
    );
    })

js操作serviceWorker缓存静态文件的更多相关文章

  1. Nginx设置Js、Css等静态文件的缓存过期时间

    location ~.*\.(js|css|html|png|jpg)$ { expires 3d; } expires    3d; //表示缓存3天 expires    3h; //表示缓存3小 ...

  2. apache下用expires_module让浏览器缓存静态文件

    让浏览器缓存CSS.JS.图片.静态文件等是很重要的事情,这样可以减轻服务器的压力,省的浏览器经常要去服务端下载这些静态文件.下面看看配置方法吧. 1.开启apache扩展模块mod_expires. ...

  3. 【摘自张宴的"实战:Nginx"】使用nginx的proxy_cache模块替代squid,缓存静态文件

    #user nobody;worker_processes 1; error_log logs/static_source.error.log;#error_log logs/error.log no ...

  4. 霸气!Nginx 中缓存静态文件秘籍

    导读 这篇教程说明你应该怎样配置 nginx.设置 HTTP 头部过期时间,用 Cache-Control 中的 max-age 标记为静态文件(比如图片. CSS 和 Javascript 文件)设 ...

  5. 用nginx缓存静态文件

        这篇教程说明你应该怎样配置 nginx.设置 HTTP 头部过期时间,用 Cache-Control 中的 max-age 标记为静态文件(比如图片. CSS 和 Javascript 文件) ...

  6. virtualBox 虚拟机下nginx设置不缓存静态文件不起作用解决办法

    最近开发的时候,调整js时会一直使用缓存文件,无法显示改动!nginx配置静态文件add_header Cache-Control no-cache;也不起作用,很苦恼! nginx配置代码:even ...

  7. nginx优化:使用expires在浏览器端缓存静态文件

    一,nginx中expires指令的作用 网站的图片等静态文件一旦发布,通常很少改动, 为了减小对服务器请求的压力,提高用户浏览速度, 我们可以设置nginx中的expires, 使用户访问一次后,将 ...

  8. tomcat 无法加载js和css 等静态文件的问题

    前段时间做了个网站,在本地tomcat测试都没有问题,但是部署到阿里云上之后,系统样式全没了.jsp等动态页面访问正常. 打开浏览器监控发现所有的css 和js 文件返回都是404 .直接访问单个的c ...

  9. SpringMVC架构的项目,js,css等静态文件导入有问题

    发生原因 <servlet> <servlet-name>springmvc-mybaits</servlet-name> <servlet-class> ...

随机推荐

  1. 分享知识-快乐自己:Ajax 跨域请求处理

    <%-- Created by IntelliJ IDEA. User: asus Date: 2019/1/24 Time: 15:57 To change this template use ...

  2. srs部署到ubuntu 18.04 server

    srs.txt ubuntu 18.04 安装 srs 1. 上传srs_40.7z和h2ws.7z到linux服务器,然后远程ssh连接 (假设登陆用户名是bob,linux服务器ip是192.16 ...

  3. BoyerMoore(BM)算法--C#

    因项目需要使用字符串查询算法,在网上搜搜了半天,没有找到C#版的. 索性根据BM机制,用C#实现了一遍.现在贴出了,以备忘记. /// <summary> /// BM算法 /// < ...

  4. 【转】安装OS X虚拟机错误vcpu-0:VERIFY vmcore/vmm/main/physMem_monitor.c:1123

    新建一个虚拟机, 选择客户机操作系统为Apple MacOS X 10.10, 其余参数可以默认. 注意建好之后不要急着打开客户机, 因为直接打开你会发现新建的客户机将会无法启动. 仔细阅读Mac O ...

  5. 【spark】常用转换操作:join

    join就表示内连接. 对于内链接,对于给定的两个输入数据集(k,v1)和(k,v2) 根据相同的k进行连接,最终得到(k,(v1,v2))的数据集. 示例 val arr1 = Array((&qu ...

  6. Java堆、栈和常量池以及相关String的详细讲解(转)

    一:在JAVA中,有六个不同的地方可以存储数据: 1. 寄存器(register). 这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部.但是寄存器的数量极其有限,所以寄存器由编译器根据 ...

  7. python练习题100例

    链接地址:http://www.runoob.com/python/python-100-examples.html

  8. react antd 动态表单

    import React, { Component } from 'react'; import ReactDOM from 'react-dom'; import { Form, InputNumb ...

  9. 在Ubuntu 14.04 TLS下openvas V8.0源代码安装过程

    [Qboy原创]详细记录源代码的安装过程 1.下载原代码 在http://www.openvas.org/install-source.html下载 Libraries 8.0.8 Scanner 5 ...

  10. ubuntu 添加新硬盘

    查看硬盘: # fdisk -l ... Disk /dev/sdb: 274.9 GB, 274877906944 bytes 255 heads, 63 sectors/track, 33418 ...