网络编程
位置:首页>> 网络编程>> 网页设计>> HTML5本地存储初探(二)

HTML5本地存储初探(二)

作者:Robin 来源:Time Machine 发布时间:2010-03-07 15:47:00 

标签:HTML5,本地存储,浏览器,webkit

完成了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;}

可以看出,基本上和php之类后端语言操作大同小异。
更多代码可查看示例程序,不再一一罗列。

搞定了数据的本地存储之后,接下来就要看看如何将文件储存到本地。

HTML5本地存储初探(三)

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com