(原创)PouchDB 图片本地存储(web离线应用)
/*
* 参数
* 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离线应用)的更多相关文章
- iOS 图片本地存储、本地获取、本地删除
在iOS开发中.经常用到图片的本地化. iOS 图片本地存储.本地获取.本地删除,可以通过以下类方法实现. p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: ...
- HTML5 本地存储Web Storage简单了解
HTML5本地存储规范,定义了两个重要的API :Web Storage 和 本地数据库Web SQL Database. 本地存储Web Storage 实际上是HTML4的cookie存储机 ...
- HTML5本地存储——Web SQL Database
在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...
- HTML5本地存储 Web Storage
Web Storage基本介绍 HTML5 定义了本地存储规范 Web Storage , 提供了两种存储类型 API sessionStorage 和 localStorage,二者的差异主要是数 ...
- [转]HTML5本地存储——Web SQL Database
在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数据就 ...
- 本地存储 web storage
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- HTML5开发学习:本地存储Web Sql Database
Web Sql Database,中文翻译作"本地数据库",是随着HTML5规范加入的在浏览器端运行的轻量级数据库. 在HTML5中,大大丰富了客户端本地可以存储的内容 ...
- HTML5本地存储——Web SQL Database与indexedDB
虽然在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数 ...
- html5本地存储web storage的简单使用
html5的一个非常cool的功能,就是web storage,类似于之前的cookie,不过与之不同的是,web storage 拥有本地5兆的容量可以存储,而cookie却只有4K,这是完全不能比 ...
随机推荐
- SpringBoot2.X自定义拦截器实战及新旧配置对比(核心知识)
简介: 讲解拦截器使用,Spingboot2.x新版本配置拦截拦截器和旧版本SpringBoot配置拦截器区别讲解 1.@Configuration 继承WebMvcConfigurationAdap ...
- python 数据类型详解
python数据类型详解 参考网址:http://www.cnblogs.com/linjiqin/p/3608541.html 目录1.字符串2.布尔类型3.整数4.浮点数5.数字6.列表7.元组8 ...
- 同步sync 异步async
线程中 同步任务是串行队列,也就是按顺序执行. 同步任务:不会开辟新的线程,它是在当前线程执行的. dispatch 调度 GCD里面的函数都是以dispatch开头的. 同步任务 步骤: 1. ...
- android 服务解析
https://blog.csdn.net/luoyanglizi/article/details/51586437 2.service和Thread的区别 定义上: thread是程序运行的最小单元 ...
- Theano教程:Python的内存管理
在写大型程序时候的一大挑战是如何保证最少的内存使用率.但是在Python中的内存管理是比较简单的.Python显示分配内存,使用引用计数系统管理对象,当指向某一个对象的引用数变为 0 的时候,该对象所 ...
- Principal components analysis(PCA):主元分析
在因子分析(Factor analysis)中,介绍了一种降维概率模型,用EM算法(EM算法原理详解)估计参数.在这里讨论另外一种降维方法:主元分析法(PCA),这种算法更加直接,只需要进行特征向量的 ...
- sga 操作命令
用SYS用户以SYSDBA身份登录系统alter system set sga_max_size=2000m scope=spfile;alter system set sga_target=2000 ...
- Python select IO多路复用
一.select介绍 Python的select()函数是底层操作系统实现的直接接口.它监视套接字,打开文件和管道(任何带有返回有效文件描述符的fileno()方法),直到它们变得可读或可写,或者发生 ...
- Docker+STF在ubuntu下测试环境搭建(详细搭建步骤及踩坑记录)
一.什么是OpenSTF? STF又称OpenSTF,它是一个手机设备管理平台,可以对手机进行远程管理.调试.远程手机桌面监控等操作.这个系统类似于目前很流行的云测服务比如Testin,虽然网页上提供 ...
- 解决vmware虚拟机克隆后启动centos报错device eth0 does not seem to be present, delaying initialization
centos启动报错: device eth0 does not seem to be present, delaying initialization ifcfg-eth0的配置文件里保存了以前的M ...