HTML5 Web SQL 数据库怎样实现多表查询

HTML5 Web SQL 数据库怎样实现多表查询,第1张

HTML5的Web SQL Databases(html5 本地数据)的确很诱惑人,当你发现可以用与mysql查询一样的查询语句来 *** 作本地数据库时,你会发现这东西挺有趣的。今天,我们一起来了解HTML 5的Web SQL Database API:openDatabase、transaction、executeSql。

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

下面将一一将介绍怎样创建打开数据库,创建表,添加数据,更新数据,删除数据,删除表 。

先介绍三个核心方法

1、openDatabase:这个方法使用现有数据库或创建新数据库创建数据库对象。

2、transaction:这个方法允许我们根据情况控制事务提交或回滚。

3、executeSql:这个方法用于执行真实的SQL查询。

第一步:打开连接并创建数据库

代码如下:

var dataBase = openDatabase("student", "10", "学生表", 1024 1024, function () { });

if (!dataBase) {

alert("数据库创建失败!");

} else {

alert("数据库创建成功!");

}

解释一下openDatabase方法打开一个已经存在的数据库,如果数据库不存在,它还可以创建数据库。几个参数意义分别是:

1,数据库名称。

2,版本号 目前为10,不管他,写死就OK。

3,对数据库的描述。

4,设置数据的大小。

5,回调函数(可省略)。

初次调用时创建数据库,以后就是建立连接了。

创建的数据库就存在本地,路径如下:

C:\Users\Administrator\AppData\Local\Google\Chrome\User Data\Default\databases\>

java发一个>

11 理解源安全

HTML5荣光引入源(origin)的概念对域安全进行了阐明和改进。源是在网络上用来建立信任关系的地址的子集。源由规则(scheme)、主机(host)、端口(post)组成。

源的概念中不考虑路径。

HTML5定义了源的序列化。源在API和协议中以字符串的形式出现。

postMessage的安全规则确保了消息不会被传递到非预期的源页面中。当发送消息时,由发送方制定接收方的源。如果发送方用来调用postMessage的窗口不具有特定的源(例如用户跳转到了其他站点),浏览器就不会传送消息。

类似地,接受消息的时候,发送方的源也被作为消息的一部分。为避免伪造,消息源由浏览器提供。接收方可以决定处理哪些消息,以及忽略哪些消息。我们可以保留一份白名单,告诉浏览器仅仅处理可信源的消息。

最好永远不要对来自第三方的字符串求值。再者,要避免使用eval方法处理应用内部字符串。可以通过windowJSON或者json,org解析器使用JSON。

12 跨文档消息通信的浏览器支持情况

常用的做法是检测XML>

JavaScript Code复制内容到剪贴板

var xhr = new XML>13 使用postMessage API

提示 HTML5定义的MessageEvent接口也是HTML5 WebSockets和HTML5 WebWorkers的一部分。HTML5的通信功能用用于接受消息的API与MessageEvent接口是一致的。其他通信类API,如EventSource API和Web Workers,也都是使用MessageEvent接口来传递消息。

14 使用postMessage API创建应用

发送消息

通过调用目标页面window对象中的postMessage()函数可发送消息,代码如下:

JavaScript Code复制内容到剪贴板

windowpostMessage("Hello, world", "porta");

第一个参数包括要发送的数据,第二个参数是消息传送的目的地。要发送消息给iframe,可以再相应iframe的contentWindow中调用postMessage,代码如下:

JavaScript Code复制内容到剪贴板

documentgetElementsByTagName("iframe")[0]contentWindowpostMessage("Hello, world", "cha");

监听消息事件

接收消息时仅需在页面中增加一个事件处理函数。当某个消息到达时,通过检查消息的来源来决定是否对这条消息进行处理。

JavaScript Code复制内容到剪贴板

windowpostMessage("Hello, world", "porta");

消息事件是一个拥有data(数据)和origin(源)属性的DOM事件。data属性是发送方传递的实际消息,而origin属性是发送来源。

源由规则(scheme)、主机(host)、端口(port)组成。

例如:由于规则不同(如),所以页面与页面的源是不同的。

源的概念中不考虑路径。如:与只是路径不同,他们是相同的源。

源在API和协议中以字符串的形式出现。

JavaScript Code复制内容到剪贴板

var originWhiteList = ["porta", "game", ""]; function checkWhiteList(origin) { for (var i=0; i<originWhiteListlength; i++) { if (origin === originWhiteList[i]) { return true; } } return false; } function messageHandler(e) { if (checkWhiteList(eorigin)) { processMessage(edata); } else { //忽略来自未知源的消息 } }

postMessage API可以适用于同源和非同源通信,鉴于它的一致性,在同源文档间通信时也推荐适用postMessage。

2 XML

作为XML在功能上有了很大的改进。主要集中在两个方面:

(1)跨源XML;

(2)进度事件(Progress events)

HTML5本地存储——Web SQL Database

在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就无能为力了,灵活大不够强大。

Web SQL Database

我们经常在数据库中处理大量结构化数据,html5引入Web SQL Database概念,它使用 SQL 来 *** 纵客户端数据库的 API,这些 API 是异步的,规范中使用的方言是SQLlite,你假如感兴趣,可以来我的裙,一起学习交流下,同时也欢迎每一位大神,前面是二五七,中间是014,后面是001,组合起来就是了,非常欢迎真心久留学习的。

三个核心方法

但是我们学一下也没什么坏处,而且能和现在W3C力推的IndexedDB做比较,看看为什么要废弃这种方案。Web SQL Database 规范中定义的三个核心方法:

openDatabase:这个方法使用现有数据库或新建数据库来创建数据库对象

transaction:这个方法允许我们根据情况控制事务提交或回滚

executeSql:这个方法用于执行SQL 查询

1本地存储localstorage

存储方式:

以键值对(Key-Value)的方式存储,永久存储,永不失效,除非手动删除。

2本地存储sessionstorage

HTML5 的本地存储 API 中的 localStorage 与 sessionStorage 在使用方法上是相同的,区别在于 sessionStorage 在关闭页面后即被清空,而 localStorage 则会一直保存。

3离线缓存(application cache)

本地缓存应用所需的文件

使用方法:

①配置manifest文件

4Web SQL

关系数据库,通过SQL语句访问

Web SQL 数据库 API 并不是 HTML5 规范的一部分,但是它是一个独立的规范,引入了一组使用 SQL *** 作客户端数据库的 APIs。

5IndexedDB

索引数据库 (IndexedDB) API(作为 HTML5 的一部分)对创建具有丰富本地存储数据的数据密集型的离线 HTML5 Web 应用程序很有用。同时它还有助于本地缓存数据,使传统在线 Web 应用程序(比如移动 Web 应用程序)能够更快地运行和响应。

以上就是关于HTML5 Web SQL 数据库怎样实现多表查询 全部的内容,包括:HTML5 Web SQL 数据库怎样实现多表查询 、百度地图api的html的自动完成是怎么实现的、【API】拿到api数据接口该怎么写到自己的HTML里面!星座运势API!等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9534065.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-29
下一篇2023-04-29

发表评论

登录后才能评论

评论列表(0条)

    保存