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


Posted in HTML / CSS onOctober 16, 2020

前言

支持离线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.如果发现其改变, 则重新加载全部清单中的资源

结构

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

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

服务端环境的搭建

npm init //生成package.json说明书文件
npm i express //安装express包
npm i --save art-template express-art-template //使用art-tmplate
// 入口文件app.js
var 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>

结果

开启服务端后:

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

关闭服务端后:

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

改变 manifest 后 再次连接服务器

CACHE MANIFEST
#v01
/public/image/01.jpg
/public/index.css

NETWORK:
*

FALLBACK:
/

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

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

再次关闭服务端后:

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

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

HTML / CSS 相关文章推荐
CSS3 伪类选择器 nth-child()说明
Jul 10 HTML / CSS
巧用CSS3 border实现图片遮罩效果代码
Apr 09 HTML / CSS
CSS3感应鼠标的背景闪烁和图片缩放动画效果
May 14 HTML / CSS
布局和排版教程 纯css3实现图片三角形排列
Oct 17 HTML / CSS
css3 transform及原生js实现鼠标拖动3D立方体旋转
Jun 20 HTML / CSS
利用CSS3实现的文字定时向上滚动
Aug 29 HTML / CSS
网页中的电话号码如何实现一键直呼效果_附示例
Mar 15 HTML / CSS
浅谈three.js中的needsUpdate的应用
Nov 12 HTML / CSS
免费获得微软MCSD证书赶快行动吧!
Nov 13 HTML / CSS
HTML5 离线应用之打造零请求、无流量网站的解决方法
Apr 25 HTML / CSS
html5本地存储之localstorage 、本地数据库、sessionStorage简单使用示例
May 08 HTML / CSS
常用的文件对应的MIME类型汇总
Apr 26 HTML / CSS
HTML+CSS+JavaScript实现图片3D展览的示例代码
Oct 12 #HTML / CSS
HTML5逐步分析实现拖放功能的方法
Sep 30 #HTML / CSS
移动端HTML5 input常见问题(小结)
Sep 28 #HTML / CSS
HTML5超文本标记语言的实现方法
Sep 24 #HTML / CSS
Html5 webRTC简单实现视频调用的示例代码
Sep 23 #HTML / CSS
Html5之webcoekt播放JPEG图片流
Sep 22 #HTML / CSS
如何在Canvas上的图形/图像绑定事件监听的实现
Sep 16 #HTML / CSS
You might like
Windows下安装PHP单元测试环境PHPUnit图文教程
2014/10/24 PHP
jQuery 页面 Mask实现代码
2010/01/09 Javascript
Javascript 实现TreeView CheckBox全选效果
2010/01/11 Javascript
json2.js的初步学习与了解
2011/10/06 Javascript
让你的博客飘雪花超出屏幕依然看得见
2013/01/04 Javascript
JS中的log对象获取以及debug的写法介绍
2014/03/03 Javascript
js 3秒后跳转页面的实现代码
2014/03/10 Javascript
Javascript玩转继承(一)
2014/05/08 Javascript
一个实用的图片切换支持点击切换和自动轮播
2014/09/09 Javascript
Jquery对select的增、删、改、查操作
2015/02/06 Javascript
JS实现文字向下滚动完整实例
2015/02/06 Javascript
JavaScript中的Math.atan2()方法使用详解
2015/06/15 Javascript
Boostrap入门准备之border box
2016/05/09 Javascript
jQuery通过改变input的type属性实现密码显示隐藏切换功能
2017/02/08 Javascript
JavaScript数据结构之二叉树的删除算法示例
2017/04/13 Javascript
web.js.字符串与正则表达式操作
2017/05/13 Javascript
让div运动起来 js实现缓动效果
2017/07/06 Javascript
JS中使用gulp实现压缩文件及浏览器热加载功能
2017/07/12 Javascript
js es6系列教程 - 新的类语法实战选项卡(详解)
2017/09/02 Javascript
基于zTree树形菜单的使用实例
2017/12/25 Javascript
微信小程序实现自定义加载图标功能
2018/07/19 Javascript
基于Vue实现图片在指定区域内移动的思路详解
2018/11/11 Javascript
微信小程序冒泡事件及其阻止方法实例分析
2018/12/06 Javascript
解决layer图标icon不加载的问题
2019/09/04 Javascript
layui+SSM的数据表的增删改实例(利用弹框添加、修改)
2019/09/27 Javascript
vue element-ui读取pdf文件的方法
2019/11/26 Javascript
[00:20]TI9观赛名额抽取Ⅱ
2019/07/24 DOTA
[01:06:43]完美世界DOTA2联赛PWL S3 PXG vs GXR 第二场 12.19
2020/12/24 DOTA
Python格式化css文件的方法
2015/03/10 Python
pymongo给mongodb创建索引的简单实现方法
2015/05/06 Python
python基础 range的用法解析
2019/08/23 Python
安全教育感言
2014/03/04 职场文书
2014年财务工作总结与计划
2014/12/08 职场文书
酒店保洁员岗位职责
2015/02/26 职场文书
房产销售员2015年终工作总结
2015/10/22 职场文书
Docker与K8s关系介绍不会Docker也可以使用K8s
2022/06/25 Servers