HTML 5 中Web SQL 的使用示例
来源:互联网 发布:怎么找淘宝套现商铺 编辑:程序博客网 时间:2024/05/22 06:45
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来进行读写,非常的方便。
示例代码
<!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 onload="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="保存" onclick="saveData();"/> </td><td ><input type="button" value="删除" onclick="deleteData();"/> </td></tr><tr><td colspan="2"><p id="msg"></p></td></tr></table><hr /><table id="datatable" border="1"></table></body></html>
对于websql,由于宽泛的读写规则,其带来的就是很大的安全问题,跨域读取,XSS攻击,SQL注入等都是非常头疼的事情。所以什么样的数据可以存储,如何存储,需要慎重考虑。W3C目前停止了该规范的更新,可能对目前的规范设计并不满意,而目前浏览器厂商的支持度也不高,后续的发展,还是未知。
1 0
- HTML 5 中Web SQL 的使用示例
- [ActiveX]Web中使用ListView 完全示例
- sql查询语句中使用if示例
- HTML多种基本标签的使用示例
- HTML本地数据库indexDataBase的使用示例
- html中隐藏域hidden的作用介绍及使用示例
- html中隐藏域hidden的作用介绍及使用示例
- html中strokeStyle示例
- html中globalAlpha示例
- html中linewidth示例
- html中linecap示例
- html中lineJoin示例
- html中transform示例
- html中settransform示例
- html表单使用示例
- 在python的web框架Django中使用SQL Server
- ImageButton控件的使用[WEB学习示例]
- HTML 5 Web SQL Database小结
- 数据库切词方法以及获取相似度的方法
- 项目六:穷举法解决组合问题(4)三色球问题
- systemtap基本用法
- 证券术语词典
- 一些有用的Emacs配置(窗口快速切换、一键透明效果、任意位置删除整行等)
- HTML 5 中Web SQL 的使用示例
- hdu 1505 dp
- iOS 动画
- 系统任务$readmemb和$readmemh
- splinter 网站测试工具简介
- GPU编程模型
- php魔术方法__autoload()
- 网站建设技术哪家强,中国武汉找八音猫科技
- Delcam_Crispin_ShoeMaker_2014_R1 鞋面设计