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

首頁 > 編程 > HTML > 正文

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

2024-08-26 00:21:08
字體:
來源:轉載
供稿:網友

有一天,我們寫了關于如何在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支持性

HTML5,IndexDB,存儲,圖像

indexDb

HTML5,IndexDB,存儲,圖像

Github源碼

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕日韩在线播放| 国产精品日韩欧美综合| 国产精品女主播| 欧美视频在线观看免费网址| 中文字幕日韩av综合精品| 亚洲xxxx在线| 日韩第一页在线| 亚洲最大福利网站| 中文字幕在线成人| 欧美性一区二区三区| 国产精品一区二区av影院萌芽| 91av免费观看91av精品在线| 亚州av一区二区| 国产精品丝袜久久久久久不卡| 国产精品自拍偷拍| 日韩视频在线观看免费| 国产精品九九久久久久久久| 欧美第一淫aaasss性| 日韩美女免费观看| 欧美一级黄色网| 亚洲xxxx在线| 日本一欧美一欧美一亚洲视频| 91性高湖久久久久久久久_久久99| 亚洲一区二区国产| 91系列在线观看| 亚洲精品suv精品一区二区| 国产狼人综合免费视频| 亚洲国产天堂久久国产91| 日韩国产中文字幕| 91视频免费在线| 黑人巨大精品欧美一区二区免费| 富二代精品短视频| 亚洲爱爱爱爱爱| 精品福利在线看| 精品视频在线观看日韩| 黑人巨大精品欧美一区二区一视频| 欧美激情一区二区久久久| 国产ts人妖一区二区三区| 欧美成人自拍视频| 亚洲国产一区二区三区在线观看| 韩剧1988免费观看全集| 亚洲老板91色精品久久| 午夜精品福利视频| 中文字幕国产亚洲2019| 国产精品第七十二页| 国产精品小说在线| 久久久亚洲福利精品午夜| 日本欧美一二三区| 欧美日韩中文字幕| 日韩成人激情在线| 国产精品免费久久久久久| 国产一区二区三区四区福利| 欧美日韩国产精品一区二区三区四区| 国内精品伊人久久| 亚洲电影免费观看高清完整版在线观看| 社区色欧美激情 | 国产日韩欧美电影在线观看| 欧美二区乱c黑人| 成人av.网址在线网站| 久久久天堂国产精品女人| 成人网欧美在线视频| 在线播放精品一区二区三区| 亚洲女人天堂色在线7777| 日韩欧美亚洲国产一区| 亚洲精品免费在线视频| 日韩av综合网| 精品国产电影一区| 中文字幕日韩欧美在线视频| 久久五月天综合| 成人妇女淫片aaaa视频| 日韩欧美在线播放| 午夜精品www| 日韩中文字幕在线观看| 亚洲自拍偷拍区| 欧美日韩亚洲国产一区| 大伊人狠狠躁夜夜躁av一区| 91久热免费在线视频| 欧美在线视频a| 日韩欧美高清视频| 欧美一级大胆视频| 91精品国产沙发| 欧美黑人一级爽快片淫片高清| 亚洲欧美国产精品专区久久| 国产一区二区欧美日韩| 一区二区三区四区在线观看视频| zzjj国产精品一区二区| 亚洲专区国产精品| 欧美疯狂做受xxxx高潮| 欧美精品在线播放| 欧美色另类天堂2015| 欧亚精品在线观看| 国语自产精品视频在线看| 国产一区二区黑人欧美xxxx| 欧美精品福利在线| 亚洲片av在线| 亚洲欧美国产精品va在线观看| 欧美成人小视频| 国产亚洲激情视频在线| 欧美在线观看一区二区三区| 91av在线免费观看| 国产精品尤物福利片在线观看| 在线播放精品一区二区三区| 国产欧美日韩精品在线观看| 隔壁老王国产在线精品| 日韩在线一区二区三区免费视频| 国产精品444| 欧美视频在线免费看| 久久免费福利视频| 国产精品爱久久久久久久| 在线日韩日本国产亚洲| 欧美另类极品videosbestfree| 亚洲视频在线观看| 精品国内亚洲在观看18黄| 国产精品女人网站| 奇米四色中文综合久久| 欧美xxxx18性欧美| 久久成人精品一区二区三区| 97人洗澡人人免费公开视频碰碰碰| 日本成人黄色片| 亚洲一区二区三区四区视频| 日韩精品在线视频观看| 色偷偷888欧美精品久久久| 国产亚洲精品成人av久久ww| 九九视频这里只有精品| 成人a级免费视频| 国产精品91视频| 国外成人在线播放| 欧美一级高清免费| 日本人成精品视频在线| 中文字幕欧美国内| 91日本在线观看| 日韩精品在线观看一区二区| 尤物tv国产一区| 日本aⅴ大伊香蕉精品视频| 在线中文字幕日韩| 成人黄色午夜影院| 国产欧美日韩中文字幕| 久久久精品日本| 日韩在线观看免费av| 日韩精品免费综合视频在线播放| 日韩电影中文字幕在线观看| 中文字幕久久久| 亚洲国产天堂久久综合| 日韩精品极品在线观看播放免费视频| 亚洲第一国产精品| 亚洲国产精品视频在线观看| 国产亚洲一区二区精品| 2019亚洲日韩新视频| 欧美性xxxx极品高清hd直播| 亚洲最大的av网站| 欧美色videos| 亚洲精品久久久久中文字幕欢迎你| 97国产精品免费视频| 91亚洲国产成人久久精品网站| 久久免费视频观看| 92看片淫黄大片看国产片| 国产精品大片wwwwww| 91国产美女在线观看| 欧美国产亚洲精品久久久8v| 精品久久国产精品| 一区二区三区日韩在线| 日韩电影在线观看免费| 91av网站在线播放| 日韩欧美一区二区三区|