您的位置:首页 > 数据库

h5缓存之数据库

2016-06-11 11:36 351 查看
/*=======================================================
函数功能:保存日志到本地数据库
=======================================================*/
function saveLog(str)
{
var db = window.openDatabase("web", "1.1", "log", 1024 * 1024);

// 创建或打开数据库失败
if(!db) { return; }

// 创建表
db.transaction(function(tx) {
tx.executeSql("CREATE TABLE if not exists log (createtime TEXT, content TEXT)");
});

// 插入记录
db.transaction(function(tx) {
tx.executeSql("INSERT INTO log (createtime, content) values(?, ?)", [new Date().Format("yyyyMMdd hh:mm:ss"), str], null, null);
});
}

/*=======================================================
函数功能:查询本地数据库里的日志信息
=======================================================*/
function selectLog(sql)
{
var db = window.openDatabase("web", "1.1", "log", 1024 * 1024);
// 创建或打开数据库失败
if(!db) { return; }

// 查询数据
db.transaction(function(tx)
{

if(sql == undefined || sql == "") { sql = "SELECT * FROM log"; }

tx.executeSql(sql, [], function(tx, result)
{
for(var i = 0; i < result.rows.length; i++)
{
console.warn( result.rows.item(i)['content']);
}
},
function()
{
console.error("查询失败! 原因:1、没有创建表; 2、表中无数据");
});
});
}

/*=======================================================
函数功能:清空数据库表数据
=======================================================*/
function clearLog()
{
var db = window.openDatabase("web", "1.1", "log", 1024 * 1024);
// 创建或打开数据库失败
if(!db) { return; }

db.transaction(function(tx) {
tx.executeSql("DROP TABLE log");
});

}


1.需求背景:当用户在页面上添加一行一行的数据时,突然发现网络断掉了,页面上编辑的数据没法保存进数据库,所以需要一个本地端的临时保存功能,以便在网络通畅后重新加载出来!

2.解决方案:

结合网上搜刮,考虑到了这几种方式:1)采用cookie; 2)看能不能采用浏览器的页面缓存来模拟 3)使用html5

1)cookie使用(做测试是直接用浏览器打开没有效果,需要放到站点下)

所有浏览器都支持,所以不需要去考虑兼容性的问题;

浏览器对于同一domain最多支持20个左右cookie,每个cookie的长度也有限制,超长部分就会被截掉

过期的限制:在cookie的生命周期内有效,过期就会被清掉

还有就是每次对服务器的请求cookie都会附带上去增加了网络带宽

鉴于以上几点考虑,并且项目中希望以文件形式存储,不予考虑!

cookie存储操作示例:

 2).localStorage

html5本地存储分为两种,一是key-value对的形式存储,一种是DateBase存储;

1.key-value本地存储有sessionStorage和localStorage两种

sessionStorage:会话存储,生命期从进入网站开始,从关闭网站后结束

localStorage:本地存储,即使关闭浏览器,再次打开时同样能够读取到存储的数据,这也是其与sessionStorage的区别

示例:

  2.html5本地数据库,提供了一套API来操作

  浏览器支持情况



3)h5File API

对于页面数据的保存,采用js库将数据json化,如:JSON.stringify(),IE的数据保存网上搜到是调用浏览器'另存为'的功能来保存成 txt,而对于chrome的数据保存调用html5的API接口blob封装数据提供给a标签的href,文件名提供给download

+ View Code

  对于本地文件的读取,采用html5 fileAPI:FileReader,通过readAsText方法读取到本地json串,JSON.parser()转回去.

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: