HTML5 知识库

html5 本地存储

   阅读:1136次   评论:1条   更新时间:2011-03-23    

HTML5本地存储初探(二)
完成了UI,我们就需要对数据进行处理了。

在开始“数据”的本地存储之前,我们先来了解一下client-side database storage API:

the client-side database storage API allows web applications to store structured data locally using a medium many web developers are already familiar with – SQL.--webkit blog

目前只有webkit核心的浏览器支持这一特性。你甚至都不能在w3c的html5工作草案中找到 (cs-db)client-side database 的详细描述。

首先我们要尝试建立一个数据库链接:

try {
if(!window.openDatabase){  //检测浏览器是否支持cs-db
alert('not supported cs-db!');
} else {
var shortName = 'noteDB';
var version = '1.0';
var displayName = 'Note book database';
var maxSize = 65536;
                //创建一个数据库
var db = openDatabase(shortName,version,displayName,maxSize);
}
} catch(e){  //尝试捕获错误
if (e == 2){
alert('Invalid database version.');
} else {
alert("Unknown error "+e+".");
}
}
如果以上代码无误,你就会在safair或者chrome的开发者工具中看到这个数据库:





在右侧区域可以直接执行一些sql查询,但是我总是得到 “发生意外错误“0”。” 这样的结果,不知道是不是RP的问题。

接下来就是创建表,以及执行一些sql语句进行增删改查。

js执行sql的基本语法大致是这样的:

db.transaction(
function (transaction){
transaction.executeSql(sqlquery,[],dataHandler, errorHandler);
}
);
其中transaction.executeSql中参数依次为:sql查询字符串,传递给sql查询的参数,数据处理句柄,错误处理句柄。其中只有第一项为必选,其余都为可选项。

第二个参数的用法大致是这样的:

transaction.executeSql("UPDATE people set age=? where name=?;",[ age, name ]);
查询字符串中的“ ?” 会被后面数组中的变量依次替换。

注意:以上我用了“大致”这个词,因为没有官方的文档 (W3C-web database),只是从一些其它文献以及自己判断得来,若有错误还请指正。

下面我们创建一张用来存储note的表:

db.transaction(
function (transaction){
transaction.executeSql(
                'CREATE TABLE IF NOT EXISTS notes (id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,titel TEXT, note TEXT NOT NULL, date DATE);',errorHandler);
}
);
errorHandler是这样的:

function errorHandler(transaction, error){
alert('Error was: '+ error.message +'(Code:'+ error.code +')');

var fatal_error = true;
if(fatal_error){
return true;
}
return false;
}
error.message 是一段错误描述,error.code 是错误代码 (详情)

再看看如果从db中检索出数据并显示到页面上:

db.transaction(
function (transaction){
transaction.executeSql("SELECT * from notes;",[],dataHandler, errorHandler);
}
);

function dataHandler(transaction, results){
var string = "";
for (var i = 0; i" + row['titel'] + "

";
}
var listConts = $('listCont');
listConts.innerHTML = string;
}

 

评论 共 1 条 请登录后发表评论
1 楼 luogen33 2011-12-13 18:35
[/b][b][b][/b]

发表评论

您还没有登录,请您登录后再发表评论

Global site tag (gtag.js) - Google Analytics