首页前端开发HTML利用Node实现HTML5离线存储的方法

利用Node实现HTML5离线存储的方法

时间2024-01-25 07:10:33发布访客分类HTML浏览443
导读:收集整理的这篇文章主要介绍了利用Node实现HTML5离线存储的方法,觉得挺不错的,现在分享给大家,也给大家做个参考。 前言支持离线Web应用开发是HTML5的一个重点。离线Web应用就是在设备不能上网的时候仍然可以运行的应用。开...
收集整理的这篇文章主要介绍了利用Node实现HTML5离线存储的方法,觉得挺不错的,现在分享给大家,也给大家做个参考。

前言

支持离线Web应用开发是HTML5的一个重点。离线Web应用就是在设备不能上网的时候仍然可以运行的应用。开发离线Web应用需要几个步骤,其中一个就是离线下必须能访问一定的资源(图像 JS css等)

HTML5引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在离线时进行访问。

:pushpin:应用程序缓存为应用带来三个优势:

  • 离线浏览 – 用户可在应用离线时使用它们
  • 速度 – 已缓存资源加载得更快
  • 减少服务器负载 – 浏览器将只从服务器下载更新过或更改过的资源。

原理和环境

  • 在线的情况下, 当浏览器渲染到 html manifest="test.manifest"> 时,会发出一个请求,请求获取 test.manifest 文件 ,如果是第一次访问,那么浏览器就会根据 描述文件(manifest 文件)中(CACHE MANIFEST)的内容下载相应的资源并且进行离线存储。如果已经访问过并且资源已经离线存储了,那么浏览器就会使用离线的资源加载页面,然后浏览器会对比新的 manifest 文件与旧的 manifest 文件,如果文件没有发生改变,就不做任何操作,如果文件改变了,那么就会重新下载文件中的资源并进行离线存储。
  • :triAngular_flag_on_post: 【注】 这个demo演示是为了更深的了解这个原理
  • 离线的情况下,浏览器就直接使用离线存储的资源
  • 就像cookie一样,HTML5的离线存储也需要服务器环境,这个demo中服务端基于Node.js、ExPress框架和art-tmplate开发

 描述文件

要想在缓存中保存数据,需要使用描述文件manifest 文件,列出要下载和缓存的资源

manifest 文件可分为三个部分:

  • CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存
  • NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓存
  • FALLBACK - 在此标题下列出的文件规定当页面无法访问时的回退页面(比如 404 页面)
  • 在线的情况下,用户代理每次访问页面,都会去读一次manifest.如果发现其改变, 则重新加载全部清单中的资源

结构

 

:triangular_flag_on_post: 【注意】 所有的你想让浏览器缓存的资源放在Public静态资源文件夹中

服务端环境的搭建

npm inIT //生成package.json说明书文件npm i exPRess //安装express包npm i --save art-template express-art-template //使用art-tmplate// 入口文件app.jsVAR express = require("express");
    var app = express();
    app.use('/public/', express.static('./public/'))app.engine('html', require('express-art-template'));
app.get('/', function (req, res) {
      res.render('index.html');
}
    );
app.listen(3000, function () {
      console.LOG("app is running at port 3000.");
}
    );
    

其它

offline.appcache描述文件

CACHE MANIFEST#v01/public/image/01.jpg //缓存第一张图片NETWORK:*FALLBACK:/

index.html

!DOCTYPE html>
    html lang="en" manifest="../public/offline.appcache">
    head>
      meta charset="UTF-8">
      title>
    HTML5离线存储/title>
      link rel="stylesheet" href="../public/index.css">
    /head>
    body>
      img src="../public/image/01.jpg" alt="">
      img src="../public/image/02.jpg" alt="">
    /body>
    /html>
    

结果

开启服务端后:

关闭服务端后:

改变 manifest 后 再次连接服务器

CACHE MANIFEST#v01/public/image/01.jpg/public/index.cssNETWORK:*FALLBACK:/

 

:triangular_flag_on_post: 【注】 看图右边控制端的输出,因为改变了manifest文件,浏览器会对比新的 manifest 文件与旧的 manifest 文件,发现文件改变了,那么就会重新下载文件中的资源并进行离线存储

再次关闭服务端后:

到此这篇关于利用Node实现HTML5离线存储的文章就介绍到这了,更多相关HTML5离线存储内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

HTML5离线存储node

若转载请注明出处: 利用Node实现HTML5离线存储的方法
本文地址: https://pptw.com/jishu/586256.html
Html5 webRTC简单实现视频调用的示例代码 移动端HTML5 input常见问题(小结)

游客 回复需填写必要信息