Skip to content

Latest commit

 

History

History
133 lines (121 loc) · 2.73 KB

README.md

File metadata and controls

133 lines (121 loc) · 2.73 KB

WebAppCache 1.0.3

轻量化的WebApp缓存管理,使用Application Cache + localStorage(SessionStorage)
intro:http://www.zawaliang.com/2013/04/277.html

[如何使用]

基本只需要两步:

  1. 按格式定义app.json
  2. 定义入口文件(如app.html)

[Demo]

目录结构如下:
WebAppCache约定app.html与app.json处于相同的目录层级,其他的资源不作要求。

app/--
 |---app.manifest
 |---app.json
 |---app.html
 |---WebAppCache.js
 |---page/
       |---index.html
       |---inner/
             |---demo.html  
 |---js/
       |---app.js
       |---demo.js
 |---css/
       |---app.css
       |---inner/
             |---demo.css

app.json应用配置文件

{
	// 配置文件过期时间(分钟)
  	"expire": "10",
  	// 离线时缓存命中失败的提示
  	"networkError": "网络连接失败",
  	// 核心加载的js文件
	"jsCore": ["app"],
	// 核心加载的css文件
	"cssCore": ["app"],
	// js配置
	"jsConfig": {
		// js基准路径
		"path": "app/js/",
		// js缺省后缀
		"suffix": ".js"
	},
	// css配置
	"cssConfig": {
		// css基准路径
		"path": "app/css/",
		// css缺省后缀
		"suffix": ".css"
	},
	// 页面配置
	"pageConfig": {
		// 页面基准路径
		"path": "app/page/",
		// 页面缺省后缀
		"suffix": ".html"
	},
	// 声明应用js资源
	"js": {
		"app": {
			// 指定拉取路径,url为空时以基准路径+模块名拉取+缺省后缀
			"url": "app/js/app.js",
			// 版本号,-1时不作缓存
			"v": "1.0.0"
		},
		"demo": {
			"url": "app/js/demo.js",
			"v": "1.0.0"
		}
	},
	// 声明应用css资源
	"css": {
		"app": {
			"url": "app/css/app.css",
			"v": "1.0.0"
		},
		"inner.demo": {
			"url": "app/css/inner/demo.css",
			"v": "1.0.0"
		}
	},
	// 声明应用页面
	"page": {
		"demo": {
			"v": "1.0.0",
			// 声明除去核心加载外需要加载的资源
      			"js": ["demo"],
			"css": ["inner.demo"]
		}
	}
}

app.html缓存调度

<!DOCTYPE html>
<html manifest="/app/app.manifest">
<head>
<title></title>
<meta charset="utf-8">
<script type="text/javascript" src="/app/WebAppCache.js"></script>
</head>
<body>
</body>
</html>

实际请求地址如下:

inner/demo.html  -> app/app.html?v=inner.demo

[一些注意事项]

  1. app.html?v=xxx中缺省为v=index
  2. 核心css资源于所有其他css资源前渲染
  3. 资源不可跨域访问
  4. 由于document.write对脚本中的script敏感,WebAppCache采取动态生成脚本执行的方式,这就可能造成页面中的脚本于缓存中的脚本前执行的问题。所以对于依赖app.json中声明的js的脚本,建议通过配置到app.json里处理来解决,这个问题后续优化解决。