• [PWA] 19. Cache the avatars


    Cache the avatars is little different from cache photos. We need to serve the page with our cache data and also go to the network for fetch avatars in case some user like change their avatars frequently.

    self.addEventListener('fetch', function(event) {
      var requestUrl = new URL(event.request.url);
    
      if (requestUrl.origin === location.origin) {
        if (requestUrl.pathname === '/') {
          event.respondWith(caches.match('/skeleton'));
          return;
        }
        if (requestUrl.pathname.startsWith('/photos/')) {
          event.respondWith(servePhoto(event.request));
          return;
        }
        // TODO: respond to avatar urls by responding with
        // the return value of serveAvatar(event.request)
        if(requestUrl.pathname.startsWith('/avatars/')){
          event.respondWith(serveAvatar(event.request));
          return;
        }
      }
    
      event.respondWith(
        caches.match(event.request).then(function(response) {
          return response || fetch(event.request);
        })
      );
    });
    function serveAvatar(request) {
      // Avatar urls look like:
      // avatars/sam-2x.jpg
      // But storageUrl has the -2x.jpg bit missing.
      // Use this url to store & match the image in the cache.
      // This means you only store one copy of each avatar.
      var storageUrl = request.url.replace(/-dx.jpg$/, '');
    
      // TODO: return images from the "wittr-content-imgs" cache
      // if they're in there. But afterwards, go to the network
      // to update the entry in the cache.
      //
      // Note that this is slightly different to servePhoto!
      return caches.open(contentImgsCache)
          .then(function(cache){
             return cache.match(storageUrl).then(function(response){
    
                 var netFetchResponse = fetch(request).then(function(networkResponse){
                     cache.put(storageUrl ,networkResponse.clone());
                     return networkResponse;
                 });
    
                 return response || netFetchResponse;
             })
          })
    }
  • 相关阅读:
    SCM基础之系统核心功能
    事件记录与变更请求
    SCM基础之配置管理功能
    SCM基础之好处
    SCM基础之配置管理实施
    善其事 利其器:快速制作SEO索引
    深入浅出之正则表达式(二)
    C# 读写文件方法总结
    C#常用正则式整理
    C#正则表达式类Match和Group类的理解
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5522116.html
Copyright © 2020-2023  润新知