/*
* 参数
* db: 已建或未建数据库
* pouchId: 数据库唯一的主键_id
* src: 图片img的DOM对象
* bg: 判断是否是背景图
* */
function addTodo(db, pouchId,src,bg) {
// 查询数据库中是否有该文档 根据主键pouchId查询
db.get(pouchId).then(function(doc) {
return db.put({ // 如有该文档 则更新版本号_rev
_id: pouchId,
_rev: doc._rev, // 版本号
imgFile:doc.imgFile //图片Blob对象
});
}).then(function(response) {
// handle response
console.log('查询成功'); // 文档查询成功
console.log(response); // 响应查询文档信息
db.get(pouchId).then(function (doc) { // 查询数据库中该主键_id的文档信息
// handle doc
var imgBlob = doc.imgFile // blob图片对象
console.log(imgBlob)
// 判断是否存在该图片对象Blob
if (imgBlob) {
// 传入blob对象 dom对象
showImg(imgBlob, src,bg);
} else {
getByRequest(db,pouchId, src);
}
}).catch(function (err) {
console.log(err);
}); }).catch(function (err) {
console.log(err);
console.log('查询失败,进行创建') // 文档查询失败
// 新建文档
db.put({
_id: pouchId
}).then(function (response) {
// handle response
console.log('创建成功')
}).catch(function (err) {
console.log(err);
});
});
} // 传入blob对象 显示图片
function showImg(imgFile, src,bg) { console.log("showImg" + imgFile); // Get window.URL object
var URL = window.URL || window.webkitURL; // Create and revoke ObjectURL
// 利用blob对象 创建一个URL对象
var imgURL = URL.createObjectURL(imgFile); // Set img src to ObjectURL
// 获取图片的dom对象 并将URL设置为该对象的SRC
var imgElephant = document.getElementById(src);
if(!bg){
imgElephant.setAttribute("src", imgURL);
}else{
imgElephant.style.background = "url("+imgURL+")";
} // Revoking ObjectURL
// 当图片加载完成后
// 使用URL.revokeObjectURL() 方法释放之前创建的URL对象
imgElephant.onload = function () {
window.URL.revokeObjectURL(this.src);
}
} // 当数据库查询主键 无该图片数据时 通过项目自身存储图片blob
function getByRequest(db,pouchId, src) {
// Create XHR
var xhr = new XMLHttpRequest(), // 创建 XMLHttpRequest 对象 目前请求项目自身
blob;
xhr.open("GET", pouchId, true); // 在项目中get请求该图片
// Set the responseType to blob
// 将响应类型设为blob类型
xhr.responseType = "blob";
// 响应加载
xhr.addEventListener("load", function () {
// 响应为200 请求完成
if (xhr.status === 200) {
console.log("Image retrieved"); // Blob as response
blob = xhr.response; // blob对象为响应后的对象
console.log("Blob:" + blob);
// 获得blob图片信息 存入pouchDB文档
save(db,blob, pouchId);
// 从pouchDB查询该文档
showImg(blob, src);
}
}, false);
// Send XHR
xhr.send();
} //根据blob对象为keyPath 更新键值
function save(db,blob, pouchId) {
// 根据主键_id 查询文档 并追加文档imgFile内容 更新版本号_rev
db.get(pouchId).then(function(doc) {
return db.put({
_id: pouchId,
_rev: doc._rev,
imgFile: blob
});
}).then(function(response) {
// handle response
console.log('图片存储成功')
console.log(response)
}).catch(function (err) {
console.log(err);
}); }
GitHub地址:https://github.com/VIVI863628/PouchDB/blob/master/IMGDB2.js

(原创)PouchDB 图片本地存储(web离线应用)的更多相关文章

  1. iOS 图片本地存储、本地获取、本地删除

    在iOS开发中.经常用到图片的本地化. iOS 图片本地存储.本地获取.本地删除,可以通过以下类方法实现. p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: ...

  2. HTML5 本地存储Web Storage简单了解

    ​HTML5本地存储规范,定义了两个重要的API :Web Storage  和  本地数据库Web SQL Database. 本地存储Web Storage 实际上是HTML4的cookie存储机 ...

  3. HTML5本地存储——Web SQL Database

    在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...

  4. HTML5本地存储 Web Storage

    Web Storage基本介绍 HTML5 定义了本地存储规范 Web Storage , 提供了两种存储类型 API  sessionStorage 和 localStorage,二者的差异主要是数 ...

  5. [转]HTML5本地存储——Web SQL Database

    在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...

  6. 本地存储 web storage

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. HTML5开发学习:本地存储Web Sql Database

       Web Sql Database,中文翻译作"本地数据库",是随着HTML5规范加入的在浏览器端运行的轻量级数据库.    在HTML5中,大大丰富了客户端本地可以存储的内容 ...

  8. HTML5本地存储——Web SQL Database与indexedDB

    虽然在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数 ...

  9. html5本地存储web storage的简单使用

    html5的一个非常cool的功能,就是web storage,类似于之前的cookie,不过与之不同的是,web storage 拥有本地5兆的容量可以存储,而cookie却只有4K,这是完全不能比 ...

随机推荐

  1. js获取当前日期时间“yyyy-MM-dd HH:MM:SS”

    获取当前的日期时间 格式“yyyy-MM-dd HH:MM:SS” 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 function getNowFormatDat ...

  2. PLSQL_day01

    declare begin  dbms_output.put_line('Hello world') end;

  3. python cookbook 笔记一

    因为有些代码只有在python3里可以正常运行,所以最好配两个虚拟环境 安装虚拟环境: pip install virtualenv virtualenv -p /usr/bin/python3.5 ...

  4. SpringBoot三种配置Dubbo的方式

    *必须首先导入dubbo-starter (1).使用SpringBoot配置文件(application.properties或application.yml) dubbo.application. ...

  5. SpringBoot整合Jdbc

    (1).添加相关依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId ...

  6. 【网络编程3】网络编程基础-arp请求(局域网主机扫描)

    ARP协议 ARP(Add ress Resolution Protocol)地址解析协议位于数据链路层,是根据IP地址获取MAC地址的一个协议. ARP 查看指令 arp -a 显示所有接口的当前A ...

  7. win7安装Ubuntu变双系统以及删除Ubuntu分区操作

    Window7系统基础上安装Ubuntu使构成双系统,整个过程如下: 1. 一块空闲磁盘分区准备. “我的电脑”右键 > 管理 > 磁盘管理 > 压缩(从有空余分区压缩)/删除(删除 ...

  8. genstr.py

    #!/usr/bin/python #-*- coding:utf-8 –*- import os import sys import re import shutil import xlrd imp ...

  9. favicon.ico问题

    在访问web的时候,有时出现favicon.ico 不知道这是一个什么东西,查看百度:

  10. CCF2014032窗口(C语言)

    问题描述 在某图形操作系统中,有 N 个窗口,每个窗口都是一个两边与坐标轴分别平行的矩形区域.窗口的边界上的点也属于该窗口.窗口之间有层次的区别,在多于一个窗口重叠的区域里,只会显示位于顶层的窗口里的 ...