首页 > 代码库 > HTML 5 中Web SQL 的使用示例

HTML 5 中Web SQL 的使用示例

Web sql 是在浏览器模拟数据库,可以使用JS来操作SQL完成对数据的读写,但是这个东西目前支持的浏览器不多,而且其W3C规范已经停止支持,貌似其前景不是很明朗。

W3C 规范:http://www.w3.org/TR/webdatabase/#dom-sqltransaction-sync-executesql (目前已经停止更新,组织也没想清楚发展方向)

支持的浏览器以及版本:

Safari (3.2+)
Chrome (3.0+)
Opera (10.5+)

通常常规的离线应用使用的是webstorage,但是webstorage带有很大的局限性,比如存储空间,domain安全机制等,而WEB SQL 就没有那么多的限制,其有更大的存储空间(可自定义设置),跨域读写,存储结构自由等特点,而且可以方便的使用SQL来进行读写,非常的方便。

示例代码

<span style="font-family:System;font-size:18px;"><!DOCTYPE html><html>	<head>		<meta charset="utf-8">		<title>使用数据库实现web留言板</title>		<script language="JavaScript">			var datatable = null;   			//使用openDatabase方法来创建一个访问数据库的对象 			var db = openDatabase('MyData', '', 'My Database', 102400);						// 初始化操作			function init() {       				datatable = document.getElementById("datatable");       				showAllData();   			}   			// 删除所有数据			function removeAllData() {       				for (var i =datatable.childNodes.length-1; i>=0; i--)      {           					datatable.removeChild(datatable.childNodes[i]);       				}       				var tr = document.createElement('tr');       				var th1 = document.createElement('th');       				var th2 = document.createElement('th');       				var th3 = document.createElement('th');       				th1.innerHTML = '姓名';       				th2.innerHTML = '留言';       				th3.innerHTML = '时间';       				tr.appendChild(th1);       				tr.appendChild(th2);       				tr.appendChild(th3);       				datatable.appendChild(tr);   			}   						// 展示每行数据			function showData(row)  {       				var tr = document.createElement('tr');       				var td1 = document.createElement('td');       				td1.innerHTML = row.NAME;       				var td2 = document.createElement('td');       				td2.innerHTML = row.MESSAGE;       				var td3 = document.createElement('td');       				var t = new Date();       				t.setTime(row.TIME);       				td3.innerHTML=t.toLocaleDateString()+" "+t.toLocaleTimeString();       				tr.appendChild(td1);       				tr.appendChild(td2);       				tr.appendChild(td3);       				datatable.appendChild(tr);     			}   			// 展示所有数据			function showAllData()  {       				db.transaction(function(tx)      {           					tx.executeSql('CREATE TABLE IF NOT EXISTS MsgData(name TEXT, message TEXT, time INTEGER)',[]);           					tx.executeSql('SELECT * FROM MsgData', [], function(tx, rs)          {               						removeAllData();               						for(var i = 0; i < rs.rows.length; i++)              {                   							showData(rs.rows.item(i));               						}           					});       				});   			}   						// 新增数据			function addData(name, message, time)  {         				db.transaction(function(tx)      {           					tx.executeSql('INSERT INTO MsgData VALUES(?, ?, ?)',[name, message, time],function(tx, rs)          {               							//document.getElementById("msg").innerHTML = "成功保存数据!";        					},           					function(tx, error)          {               							alert(error.source + "::" + error.message);            					});       				});   			}   			// 保存数据			function saveData() {       				var name = document.getElementById('name').value;       				var memo = document.getElementById('memo').value;       				var time = new Date().getTime();       				addData(name,memo,time);       				showAllData();   			} 			// 删除表中数据			function deleteData(){				db.transaction(function(tx){					tx.executeSql("DELETE FROM MsgData",[],function(tx, rs)          {               							//alert("数据删除成功!");           					},           					function(tx, error)          {               							alert(error.source + "::" + error.message);           					});				});				showAllData();			}		</script>	</head>	<body onl oad="init()">		<h1>使用数据库实现web留言板</h1>		<table>			<tr>				<td><label>姓名:</label></td>				<td><input type="text" id="name" /> </td>			</tr>			<tr>				<td><label>留言:</label></td>				<td><input type="text" id="memo" /> </td>			</tr>			<tr>				<td ><input type="button" value=http://www.mamicode.com/"保存" onclick="saveData();"/> >


对于websql,由于宽泛的读写规则,其带来的就是很大的安全问题,跨域读取,XSS攻击,SQL注入等都是非常头疼的事情。所以什么样的数据可以存储,如何存储,需要慎重考虑。W3C目前停止了该规范的更新,可能对目前的规范设计并不满意,而目前浏览器厂商的支持度也不高,后续的发展,还是未知。

 

HTML 5 中Web SQL 的使用示例