亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

使用HTML5 IndexDB存儲圖像和文件的示例

2024-09-05 07:19:17
字體:
來源:轉載
供稿:網友

有一天,我們寫了關于如何在localStorage中保存圖像和文件的文章,它是關于我們今天可用的實用主義。 然而,localStorage有一些性能影響 - 我們將在稍后的博客中討論這個問題 - 并且未來期望的方法是使用IndexedDB。 在這里,我將向您介紹如何在IndexedDB中存儲圖像和文件,然后通過ObjectURL呈現它們。

本文是翻譯過來的,原文在這里 Storing images and files in IndexedDB

關于作者: Robert Nyman [Editor emeritus]

Technical Evangelist & Editor of Mozilla Hacks. Gives talks & blogs about HTML5, JavaScript & the Open Web. Robert is a strong believer in HTML5 and the Open Web and has been working since 1999 with Front End development for the web - in Sweden and in New York City. He regularly also blogs atrobertnyman.com and loves to travel and meet people.

使用IndexDB存儲圖像和文件的常規步驟

首先,我們來談談我們將創建一個IndexedDB數據庫,將文件保存到其中然后將其讀出并顯示在頁面中的步驟:

1、創建或打開數據庫
2、創建一個objectStore
3、將圖像文件檢索為blob
4、初始化一個數據庫事物
5、保存圖像blob到數據庫中去
6、讀出保存的文件并從中創建ObjectURL并將其設置為頁面中圖像元素的src

1、創建或打開數據庫。

// IndexedDBwindow.indexedDB = window.indexedDB || window.webkitIndexedDB || window.mozIndexedDB || window.OIndexedDB || window.msIndexedDB,    IDBTransaction = window.IDBTransaction || window.webkitIDBTransaction || window.OIDBTransaction || window.msIDBTransaction,    dbVersion = 1;/*     Note: The recommended way to do this is assigning it to window.indexedDB,    to avoid potential issues in the global scope when web browsers start     removing prefixes in their implementations.    You can assign it to a varible, like var indexedDB… but then you have     to make sure that the code is contained within a function.*/// Create/open databasevar request = indexedDB.open("elephantFiles", dbVersion);request.onsuccess = function (event) {    console.log("Success creating/accessing IndexedDB database");    db = request.result;    db.onerror = function (event) {        console.log("Error creating/accessing IndexedDB database");    };        // Interim solution for Google Chrome to create an objectStore. Will be deprecated    if (db.setVersion) {        if (db.version != dbVersion) {            var setVersion = db.setVersion(dbVersion);            setVersion.onsuccess = function () {                createObjectStore(db);                getImageFile();            };        }        else {            getImageFile();        }    }    else {        getImageFile();    }}// For future use. Currently only in latest Firefox versionsrequest.onupgradeneeded = function (event) {    createObjectStore(event.target.result);};

使用它的預期方法是在創建數據庫時觸發onupgradeneeded事件或獲取更高版本號。 目前僅在Firefox中支持此功能,但很快將在其他Web瀏覽器中支持。 如果Web瀏覽器不支持此事件,則可以使用已棄用的setVersion方法并連接到其onsuccess事件。

2、創建一個objectStore(如果它尚不存在)

// Create an objectStoreconsole.log("Creating objectStore")dataBase.createObjectStore("elephants");

在這里,您創建一個ObjectStore,您將存儲數據 - 或者在我們的例子中,文件 - 并且一旦創建,您不需要重新創建它,只需更新其內容即可。

3、將圖像文件檢索為blob

// Create XHRvar xhr = new XMLHttpRequest(),    blob;xhr.open("GET", "elephant.png", true);// Set the responseType to blobxhr.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 XHRxhr.send();

此代碼直接將文件的內容作為blob獲取。目前只支持Firefox。 收到整個文件后,將blob發送到函數以將其存儲在數據庫中。

4、初始化一個數據庫事物

// Open a transaction to the databasevar transaction = db.transaction(["elephants"], IDBTransaction.READ_WRITE);

要開始向數據庫寫入內容,您需要使用objectStore名稱和要執行的操作類型(在本例中為read和write)啟動事務。

5、保存圖像blob到數據庫中去

// Put the blob into the dabasetransaction.objectStore("elephants").put(blob, "image");

一旦事務到位,您將獲得對所需objectStore的引用,然后將您的blob放入其中并為其提供密鑰。

6、讀出保存的文件并從中創建ObjectURL并將其設置為頁面中圖像元素的src

// Retrieve the file that was just storedtransaction.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);};

使用相同的事務來獲取剛剛存儲的圖像文件,然后創建一個objectURL并將其設置為頁面中圖像的src。 例如,這也可以是一個附加到腳本元素的JavaScript文件,然后它將解析JavaScript。

最后完整代碼

(function () {    // IndexedDB    var indexedDB = window.indexedDB || window.webkitIndexedDB || window.mozIndexedDB || window.OIndexedDB || window.msIndexedDB,        IDBTransaction = window.IDBTransaction || window.webkitIDBTransaction || window.OIDBTransaction || window.msIDBTransaction,        dbVersion = 1.0;    // Create/open database    var request = indexedDB.open("elephantFiles", dbVersion),        db,        createObjectStore = function (dataBase) {            // Create an objectStore            console.log("Creating objectStore")            dataBase.createObjectStore("elephants");        },        getImageFile = function () {            // 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");                                        // Blob as response                    blob = xhr.response;                    console.log("Blob:" + blob);                    // Put the received blob into IndexedDB                    putElephantInDb(blob);                }            }, false);            // Send XHR            xhr.send();        },        putElephantInDb = function (blob) {            console.log("Putting elephants in IndexedDB");            // Open a transaction to the database            var transaction = db.transaction(["elephants"], IDBTransaction.READ_WRITE);            // Put the blob into the dabase            var put = transaction.objectStore("elephants").put(blob, "image");            // 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);            };        };    request.onerror = function (event) {        console.log("Error creating/accessing IndexedDB database");    };    request.onsuccess = function (event) {        console.log("Success creating/accessing IndexedDB database");        db = request.result;        db.onerror = function (event) {            console.log("Error creating/accessing IndexedDB database");        };                // Interim solution for Google Chrome to create an objectStore. Will be deprecated        if (db.setVersion) {            if (db.version != dbVersion) {                var setVersion = db.setVersion(dbVersion);                setVersion.onsuccess = function () {                    createObjectStore(db);                    getImageFile();                };            }            else {                getImageFile();            }        }        else {            getImageFile();        }    }        // For future use. Currently only in latest Firefox versions    request.onupgradeneeded = function (event) {        createObjectStore(event.target.result);    };})();

瀏覽器支持

URL API支持性

indexDb

Github源碼

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产精品一区二区久| 中文字幕日韩在线播放| 欧美在线观看网站| 欧美精品久久久久a| 国产精品久久999| 国产日韩换脸av一区在线观看| 日韩av影视在线| 亚洲夜晚福利在线观看| 日韩精品在线看| 亚洲天堂第一页| 欧美激情aaaa| 国产精品一区二区性色av| 久久久久久国产免费| 亚洲欧美变态国产另类| 97超碰蝌蚪网人人做人人爽| 欧美又大又粗又长| 国产啪精品视频| 国产精品九九久久久久久久| 久久99久国产精品黄毛片入口| 欧美贵妇videos办公室| 亚洲精品在线观看www| 亚洲精品videossex少妇| 欧美伊久线香蕉线新在线| 欧美成人午夜激情视频| 成人做爰www免费看视频网站| 日本午夜在线亚洲.国产| 亚洲精品二三区| 国产成人高潮免费观看精品| 久久久噜噜噜久久中文字免| 久久噜噜噜精品国产亚洲综合| 亚洲国语精品自产拍在线观看| 国产日韩欧美日韩| xxxxxxxxx欧美| 国产免费一区二区三区香蕉精| 久久久久久这里只有精品| 欧美日本高清视频| 久久男人的天堂| 精品福利在线视频| 国内精品在线一区| 欧美极品美女视频网站在线观看免费| 福利视频导航一区| …久久精品99久久香蕉国产| 欧美另类交人妖| 欧美在线亚洲在线| 国产成人精品免高潮在线观看| 亚洲摸下面视频| 亚洲aa在线观看| 欧美色videos| 成人亲热视频网站| 一区二区三区四区视频| 国产精品久久99久久| 高清在线视频日韩欧美| www.久久久久久.com| 国产精品视频网址| 中文字幕日韩欧美精品在线观看| 亚洲激情视频在线播放| 91精品久久久久久久久久久久久久| 欧美国产日韩一区| 毛片精品免费在线观看| 国产亚洲欧美日韩一区二区| 精品久久久久久久久久| 欧美天天综合色影久久精品| 亚洲欧美激情一区| 国内偷自视频区视频综合| 久久免费少妇高潮久久精品99| 日韩成人在线视频网站| 欧美性生活大片免费观看网址| 国产香蕉精品视频一区二区三区| 色综合视频一区中文字幕| 成人激情视频在线观看| 久久久久久久电影一区| 奇米影视亚洲狠狠色| 黑人巨大精品欧美一区二区| 国产精品麻豆va在线播放| 欧美尤物巨大精品爽| 国产精品久久婷婷六月丁香| 国产精品www色诱视频| 欧美大片网站在线观看| 亚洲天堂2020| 欧美日韩国产在线播放| 亚洲精品欧美一区二区三区| 亚洲欧美日韩图片| **欧美日韩vr在线| 91极品视频在线| 黑人巨大精品欧美一区二区一视频| 国产精品成人一区二区三区吃奶| 亚洲字幕一区二区| 国产精品久久久久久久久| 精品丝袜一区二区三区| 欧美电影免费观看| 夜夜嗨av一区二区三区免费区| 亚洲白拍色综合图区| 国产精品久久久久免费a∨| 亚洲男人天堂2024| 亚洲免费成人av电影| 欧美精品久久一区二区| 成人亲热视频网站| 国产91精品黑色丝袜高跟鞋| 国产91在线播放精品91| 一个色综合导航| 亚洲国产精品人久久电影| 高清一区二区三区四区五区| 国内精品模特av私拍在线观看| 亚洲欧洲国产精品| 久久久久久久999| 成人性生交大片免费观看嘿嘿视频| 国产精品亚洲片夜色在线| 黑人精品xxx一区一二区| 宅男66日本亚洲欧美视频| 97精品国产97久久久久久免费| 日本人成精品视频在线| 人人做人人澡人人爽欧美| 欧美插天视频在线播放| 久久久久日韩精品久久久男男| 亚洲aⅴ男人的天堂在线观看| 亚洲xxxx在线| 国产女人精品视频| 在线电影av不卡网址| 亚洲黄色免费三级| 日韩免费av在线| 国产精品三级美女白浆呻吟| 欧美野外wwwxxx| 亚洲色图国产精品| 777午夜精品福利在线观看| 91精品国产高清久久久久久91| 亚洲a成v人在线观看| 国产伊人精品在线| 国自产精品手机在线观看视频| 日本精品免费一区二区三区| 日韩av高清不卡| 国产精品美女无圣光视频| 亚洲综合色激情五月| 国产精品久久久久久久7电影| 黑人巨大精品欧美一区免费视频| 日韩欧美在线视频免费观看| 91精品视频专区| 国产乱人伦真实精品视频| 欧美日韩一区二区精品| 性欧美办公室18xxxxhd| 亚洲区中文字幕| 国产国语videosex另类| 国模叶桐国产精品一区| 国产精品久久久精品| 亚洲欧美中文字幕| 亚洲片在线观看| 538国产精品视频一区二区| 亚洲va电影大全| 国产午夜精品一区二区三区| 91精品国产91久久久久久| 68精品国产免费久久久久久婷婷| 日韩亚洲精品视频| 国内精品400部情侣激情| 九九热精品视频国产| 欧美成人一区二区三区电影| 国产不卡精品视男人的天堂| 亚洲精品99久久久久| 欧美激情视频给我| 在线亚洲国产精品网| 夜夜嗨av色综合久久久综合网| 欧美亚洲视频一区二区| 亚洲剧情一区二区| 91久久久久久| 日韩中文字幕不卡视频| 成人高清视频观看www|