HTML5 — Wed SQL 本地数据库示例


1 <!DOCTYPE html>2 <html lang="en">3 <head>4    <meta charset="UTF-8">5    <title>Title</title>6    <script src="sql.js"></script>7 </head>8 <!--打开网页即调用init()函数,显示已存数据-->9 <body >10    <table>11        <tr><td>姓名:</td><td><input type="text" id="name"></td></tr>12        <tr><td>留言:</td><td><input type="text" id="memo"></td></tr>13        <tr>14            <td></td>15            <!--事件触发-->16            <td><input type="button" value="保存" onclick="saveData()"></td>17        </tr>18    </table>19 <hr>20 <table id="datatable" border="1">21    <p id="msg"></p>22 </table>23 </body>34 </html>

sql.js 1 // 1、创建访问数据库的对象
 2 // 2、使用事务处理
 3 var datatbale = null;
 4 var db = openDatabase("Mydata","","My Database",1024*100);
 5 /*
 6     openDatabase(),作用打开数据,如果数据库不存在,则会创建一个新的数据库。
 7     五个参数说明:数据库名称、版本号、描述文本、数据库大小、创建回调
 8 */
 9 function init() {
10     datatbale = document.getElementById("datatable");
11     showAllData();
12 }
13 //清除数据,保留表头
14 function removeAllData() {
15     for(var i = datatbale.childNodes.length -1; i>=0;i--){
16         datatbale.removeChild(datatbale.childNodes[i]);
17     }
18     var tr = document.createElement("tr");
19     var th1 = document.createElement("th");
20     var th2 = document.createElement("th");
21     var th3 = document.createElement("th");
22     th1.innerHTML = "姓名";
23     th2.innerHTML = "留言";
24     th3.innerHTML = "时间";
25     tr.appendChild(th1);
26     tr.appendChild(th2);
27     tr.appendChild(th3);
28     datatbale.appendChild(tr);
29 }
30 //显示数据
31 function showData(row) {
32     var tr = document.createElement("tr");
33     var td1 = document.createElement("td");
34     td1.innerHTML = row.name;
35     var td2 = document.createElement("td");
36     td2.innerHTML = row.message;
37     var td3 = document.createElement("td");
38     var t = new Date();
39     t.setTime(row.time);
40     td3.innerHTML = t.toLocaleDateString()+" "+ t.toLocaleTimeString();
41     tr.appendChild(td1);
42     tr.appendChild(td2);
43     tr.appendChild(td3);
44     datatbale.appendChild(tr);
45 }
46 //事件处理,先清除数据再利用for循环调用showData()函数显示所有数据
47 function showAllData() {
48     db.transaction(function (tx) {
49         tx.executeSql("CREATE TABLE IF NOT EXISTS MsgData(name TEXT,message TEXT,time INTEGER)",[]);
50         tx.executeSql("SELECT * FROM MsgData",[],function (tx,rs) {
51             removeAllData();
52             for(var i = 0;i<rs.rows.length;i++){
53                 showData(rs.rows.item(i));
54             }
55         })
56     })
57 }
58 //如何被调用?
59 function addData(name,message,time) {
60     /*
61     transaction()函数,用以处理事务:
62     包含事务内容的一个方法
63     执行成功回调函数(可选)
64     执行失败回调函数(可选)
65     */
66     db.transaction(function (tx) {
67         /*
68         executeSql()函数用以执行SQL语句,返回结果,方法有四个参数
69         1、查询字符串
70         2、用以替换查询字符串中问号的参数
71         3、执行成功回调函数(可选)
72         4、执行失败回调函数(可选)
73         */
74         tx.executeSql("INSERT INTO MsgData VALUES(?,?,?)",[name,message,time],function (tx,rs) {
75             alert("成功");
76         },
77             function (tx,erro) {
78                 alert(erro.source+"::"+erro.message);
79             }
80         )
81     })
82 }
83 //保存数据,并调用showAllData()函数显示所有数据
84 function saveData() {
85     var name = document.getElementById("name").value;
86     var memo = document.getElementById("memo").value;
87     var time = new Date().getTime();
88     addData(name,memo,time);
89     showAllData();
90 }

时间: 2024-11-12 22:08:23

HTML5 — Wed SQL 本地数据库示例的相关文章

HTML5中的本地、WebSql、离线应用存储

1.   HTML5存储相关API a)   Localstorage 本地存储 b)   Web Sql DataBase 本地数据库存储 c)   .manifest 离线应用存储 2.   HTML5 localStorage 本地存储: a)   本地存储是一个window的属性:, 相当于一个大型的Cookie; b)   window.localStorage : c)   set方法: i.      localStorage.t1 = “aaa”; ii.      localS

(转)HTML5 本地数据库(SQLite) 示例

  HTML5 本地数据库(SQLite) 示例 2012-05-07 16:21:13 标签:SQLite HTML5本地数据库 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://supercharles888.blog.51cto.com/609344/856071 按照国内一HTML5先行者的例子仿写了一个用HTML5 API来操作本地SQLite数据库的例子,感觉这个功能蛮好玩的,但是还不够强大,尤其浏览器支持力度不够:

HTML5教程之html 5 本地数据库(Web Sql Database)

HTML5的Web SQL Databases(html5 本地数据库)的确很诱惑人,当你发现可以用与mysql查询一样的查询语句来操作本地数据库时,你会发现这东西挺有趣的.今天,我们一起来了解HTML 5的Web SQL Database API:openDatabase.transaction.executeSql. Web SQL数据库API实际上不是HTML5规范的组成部分,而是单独的规范.它通过一套API来操纵客户端的数据库.Safari.Chrome.Firefox.Opera等主流

html5本地存储(三)--- 本地数据库 indexedDB

html5内置了2种本地数据库,一是被称为"SQLLite",可以通过SQL语言来访问文件型SQL数据库.二是被称为"indexedDB" 的NoSQL类型的数据库,本篇主要讲indexedDB数据库. 该数据库是一种存储在客户端本地的NoSQL数据库,目前chrome11以上.Firefox4以上.Opera18以上.Safar8以上及IE10以上的浏览器提供支持 一.连接数据库 使用indexedDB.open方法连接数据库 var dbName = 'inde

HTML5 — Wed Storage简单示例

一.Wed Storage 概述 Wed Storage功能:在Wed上储存数据的功能,这里的储存是针对客户端本地而言的. 具体分为两种: sessionStorage,将数据保存在session对象中.session是指用户在浏览某网站时,从进入网站到浏览器关闭所经过的这段时间,也是用户浏览这个网站所花费的时间.session对象可以用来保存在这段时间内所要求保存的如何数据. localStorage,将数据保存在客户端本地的硬件设备(硬盘)中,即使浏览器被关闭了,该数据仍然存在,下次打开浏览

HTML5系列三(多媒体播放、本地存储、本地数据库、离线应用)

各浏览器对编码格式的支持情况 audio和video元素的属性介绍 1.src:媒体数据的URL地址 <video src="pr6.mp4"></video> <video src="pr6.mp4" width="320" height="240"></video> 2.autoplay:是否自动播放 <video src="pr6.mp4" aut

HTML5笔记3——Web Storage和本地数据库

上一篇:HTML5笔记2——HTML5音/视频标签详解 Web Storage概述 在HTML5中,除了Canvas元素之外,另一个新增的非常重要的功能是可以再客户端本地保存数据的Web Storage功能,之前可以使用Cookies在客户端 保存诸如用户名等简单用户信息,但通过长期使用,人们发现使用Cookies存储永久数据存在几个问题. 大小:Cookies的大小被限制在4KB 带宽:Cookies是随HTTP失误一起被发送的,因此会浪费一部分发送Cookies时使用的带宽 复杂性:要正确的

Html5 学习系列(六)Html5本地存储和本地数据库

一个网站如何能在客户的浏览器存储更多的数据呢? 在Html4的时代在浏览器端存储点网站个性化的数据,尤其是用户浏览器的痕迹,用户的相关数据等一般只能存储在Cookie中,但是大多是浏览器对于Cookie的限制也就逼迫网站存储数据尽量精简,想存储复杂的.关系型的用户数据就根本不可能了.但是进入Html5时代,这一切都不叫事... 一.本地存储由来的背景 众所周知Html4时代Cookie的大小.格式.存储数据格式等限制,网站应用如果想在浏览器端存储用户的部分信息,那么只能借助于Cookie.但是C

html5的本地数据库

之前的应用一直用的是html5的本地存储LocvalStorage,挺方便也很实用. 最近开始做一个类似于离线电话簿的应用,于是得学习html5的本地数据库. sql语言大体上还是相同的,当然也有不一样的地方,我觉得以sqlite的为标准不容易出错. 开始前对html websql的操作可以有一下几种方式备选: 1:使用js和html5原生的方式来操作: 2:使用appcan开发环境中的数据库模块来操作: 该模块包含了appcan对数据库的基础操作 appcan.database.create(