IndexedDB学习三:保存图片和文件

[b]目标:[/b]
[list]
[*] 创建和大概数据库(省略)
[*] 创建对象存储(省略)
[*] 以BLOB形式获取图片文件
[*] 启动数据库事务(省略)
[*] 保存blob到数据库
[*] 读取保存文件,创建ObjectURL在页面展示
[/list]

[b]以blob形式获取图片文件:[/b]

// Create XHR
var xhr = new XMLHttpRequest(),
blob;

xhr.open("GET", "elephant.png", true);
// Set the responseType to blob
xhr.responseType = "blob";

xhr.addEventListener("load", function () {
if (xhr.status === 200) {
console.log("Image retrieved");

// File as response
blob = xhr.response;

// Put the received blob into IndexedDB
putElephantInDb(blob);
}
}, false);
// Send XHR
xhr.send();

[b]保存blob到数据库:[/b]

transaction.objectStore("elephants").put(blob, "image");

[b]读取保存文件,创建ObjectURL在页面展示:[/b]

// Retrieve the file that was just stored
transaction.objectStore("elephants").get("image").onsuccess = function (event) {
var imgFile = event.target.result;
console.log("Got elephant!" + imgFile);

// Get window.URL object
var URL = window.URL || window.webkitURL;

// Create and revoke ObjectURL
var imgURL = URL.createObjectURL(imgFile);

// Set img src to ObjectURL
var imgElephant = document.getElementById("elephant");
imgElephant.setAttribute("src", imgURL);

// Revoking ObjectURL
URL.revokeObjectURL(imgURL);
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值