web API简介(四):客户端储存之IndexedDB API

概述

前篇:web API简介(三):客户端储存之Web Storage API

客户端储存从某一方面来说和动态网站差不多。动态网站是用服务端来储存数据,而客户端储存是用客户端来储存数据。

IndexedDB API就是现代HTML5客户端储存的方法之二。

IndexedDB介绍

IndexedDB是专门为大量结构化数据设计的。

IndexedDB有这些特性

(1)IndexedDB数据库储存的是键值对。

(2)IndexedDB是基于事务型数据库模型的。

(3)IndexedDB API是异步型的。

(4)IndexedDB使用很多请求(requests)和响应。

(5)IndexedDB使用DOM通知你,当结果被返回的时候。

(6)IndexedDB数据库是对象型的数据库。

(7)IndexedDB不使用SQL。

(8)IndexedDB遵循同源政策。



IndexedDB有这些限制

(1)不支持排序。

(2)不支持同步操作。你必须自己写同步操作代码。

(3)不支持全文搜索,不支持类似SQL中的LIKE功能。

储存限制

indexedDB的Storage属性有2种:永久型和临时型。

永久型数据没有任何限制,永久储存,只有当用户删除它的时候才会被删除。

临时型数据有一个全局限制和同源限制。全局限制是指临时性数据的总量是50%的磁盘总量。当超出的时候,浏览器会自动删除最久远被用到的数据,直到可以储存目前需要储存的数据。同源限制是指同源下的临时型数据总量有一个限制,这个限制是全局限制的20%,但不低于10M,且不超过2G。当超出同源限制的时候,浏览器会抛出一个错误。

IndexedDB的使用模式

和MongoDB的使用差不多,具体如下:

(1)打开一个数据库。

(2)在数据库中建立一个object store。

(3)开始一项事务,并且用请求来操作数据库。

(4)通过监听DOM事件等待事务完成。

(5)利用返回的数据(request object)做一些操作。

使用IndexedDB

检验是否支持IndexedDB

if (!window.indexedDB) {
    window.alert("Your browser doesn't support a stable version of IndexedDB. Such and such feature will not be available.");
}

打开IndexedDB数据库

var request = window.indexedDB.open("MyTestDatabase", 3);

其中3是版本号。版本号不能用小数,否则会被四舍五入成整数。

更新IndexedDB数据库版本

在request发出后,onerror和onsuccess响应前,如果打开的IndexedDB数据库版本比已经存在的数据库版本低,那么就会出现onerror,如果如果打开的IndexedDB数据库版本比已经存在的数据库版本高,就会响应onupgradeneeded事件。

var request = indexedDB.open(dbName, 2);

//存在的数据库版本比2低的时候响应如下事件。
request.onupgradeneeded = function(event) {

  //数据库在event.target的resule属性里面
  var db = event.target.result;

  //建立object store,并设立键值
  var objectStore = db.createObjectStore("customers", { keyPath: "ssn" });

  //设定object store的索引name,并设定为可以重复
  objectStore.createIndex("name", "name", { unique: false });

  //设定object store的索引email,并设定为不可以重复
  objectStore.createIndex("email", "email", { unique: true });
  };

也可以利用autoIncrement设定一个自增长的键值。

//建立object store,并设立自增长的键值,储存在key字段中
var objectStore = db.createObjectStore("customers", { autoIncrement: true });

等待并返回IndexedDB数据库

var db;
request.onerror = function(event) {
  alert("Why didn't you allow my web app to use IndexedDB?!");
};
request.onsuccess = function(event) {
  db = event.target.result;
};

占坑

占坑

原文地址:https://www.cnblogs.com/yangzhou33/p/8449010.html

时间: 2024-07-31 15:37:42

web API简介(四):客户端储存之IndexedDB API的相关文章

web API简介(三):客户端储存之Web Storage API

概述 前篇:web API简介(二):客户端储存之document.cookie API 客户端储存从某一方面来说和动态网站差不多.动态网站是用服务端来储存数据,而客户端储存是用客户端来储存数据.document.cookie API就是实现客户端储存的最原始方法. Web Storage 先占个坑 原文地址:https://www.cnblogs.com/yangzhou33/p/8445865.html

web API简介(二):客户端储存

概述 web API简介(一):API,Ajax和Fetch 客户端储存从某一方面来说和动态网站差不多.动态网站是用服务端来储存数据,而客户端储存是用客户端来储存数据. 老式的cookies 以前的网站都是用cookies来储存数据,但是这种方法有很多问题. 这种方法只有一个优点,就是和老式的浏览器很兼容.0.0 明天写 Web Storege 明天写 IndexedDB 明天写 Service Work 和 Cache API 明天写 原文地址:https://www.cnblogs.com/

Pomelo开发中Web客户端开发API简介

使用pomelo做服务端开发时,无论什么客户端,只要能遵循与服务端的线上协议,就能够与服务端建立通信.pomelo内建提供的sioconnector和hybridconnector都定义了自己的协议格式,其中sioconnector用于socket.io的通信,hybridconnector则用来处理websocket和tcp的连接通信.为了方便客户端的开发,pomelo提供了部分平台的客户端SDK,主要包括用于Web端的JavaScript的SDK以及基于C/C++语言开发的libpomelo

Web Api 简介

ASP.NET Web API 简介 ASP.NET MVC 4 包含了 ASP.NET Web API, 这是一个创建可以连接包括浏览器.移动设备等多种客户端的 Http 服务的新框架, ASP.NET Web API 也是构建 RESTful 服务的理想平台. ASP.NET Web API 特性 ASP.NET Web API 包含下列特性: 先进的 HTTP 编程模型: 使用新的强类型的 HTTP 对象模型直接操作 HTTP 请求和响应, 在 HTTP客户端使用相同的编程模型和 HTTP

ASP.NET Web API 简介

ASP.NET Web API 简介 ASP.NET MVC 4 包含了 ASP.NET Web API, 这是一个创建可以连接包括浏览器.移动设备等多种客户端的 Http 服务的新框架, ASP.NET Web API 也是构建 RESTful 服务的理想平台. ASP.NET Web API 特性 ASP.NET Web API 包含下列特性: 先进的 HTTP 编程模型: 使用新的强类型的 HTTP 对象模型直接操作 HTTP 请求和响应, 在 HTTP客户端使用相同的编程模型和 HTTP

使用 ASP.NET Core MVC 创建 Web API(四)

原文:使用 ASP.NET Core MVC 创建 Web API(四) 使用 ASP.NET Core MVC 创建 Web API 使用 ASP.NET Core MVC 创建 Web API(一) 使用 ASP.NET Core MVC 创建 Web API(二) 使用 ASP.NET Core MVC 创建 Web API(三) 十三.返回值 在上一篇文章(使用 ASP.NET Core MVC 创建 Web API(二))中我们创建了GetBookItems和 GetBookItem两

ASP.NET MVC4中调用WEB API的四个方法

http://tech.it168.com/a2012/0606/1357/000001357231_all.shtml [IT168技术]当今的软件开发中,设计软件的服务并将其通过网络对外发布,让各种客户端去使用服务已经是十分普遍的做法.就.NET而言,目前提供了Remoting,WebService和WCF服务,这都能开发出功能十分强大的服务.然而,越来越多的互联网应用,希望将服务只是通过HTTP发布出去,而不是使用复杂的SOAP协议.为了解决这个问题,ASP.NET WebAPI就出现了.

Web API 2 (一)之Web Service简介

Web Service 是什么? Web Service 也叫作XML Web Service,是一种网络化的,分布式的软件系统,通常通过Http交付,可以跨编程语言和操作系统进行远程调用操作,通常情况下,Web Service包括服务本身和客户端,后者也被称为消费者或请求者,可以通过网络访问部署在服务器提供的某种服务(通过调用Web服务对外公开的访问接口).其可以是网页浏览器,一个桌面应用,更甚至是一个没有图形界面的应用程序 图 1.1 一个Web 服务和它的一个客户端 根据定义,Web服务和

Java web基础总结四之—— Servlet基础

Java web基础总结四之-- Servlet基础 一.什么是Servlet? 通过名字就能看出来,Servlet 就是在服务器上运行的小程序.Servlet是sun公司(现在已经属于oracle了)实现的一门用于开发动态java web资源的技术.Sun公司在其API中提供了一个servlet接口,如果你想开发一个动态的java web资源,需要完成以下2个步骤:编写一个Java类,实现servlet接口.把开发好的Java类部署到web服务器中. Servlet接口已经有了两个默认的实现类