日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

IndexedDB使用(基本函数封到Angular2的service里)

發布時間:2023/12/31 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 IndexedDB使用(基本函数封到Angular2的service里) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

IndexedDB使用

使用場景

  • 具體使用場景:

存儲用戶瀏覽記錄。

  • 適合的使用場景:
  • 處于安全性考慮,數據不能存儲到服務器端。
  • 數據為結構性數據或者數據量較大,不適合使用cookies。
  • 希望數據不隨著客戶清理緩存而刪除。此時我們一定一定要設計好清理瀏覽器端數據的時機。
  • 相關站點

  • MDN文檔(中英) 訪問
  • IBM develoerWorks(中文) 訪問
  • 這個可能是最權威的了吧,W3C(英文)訪問
  • ps:那么多好的資料了,為什么還寫博客?

  • 做筆記;
  • 我用的Angular2,語法糖是ES6的啊。
  • 代碼段

    代碼段來自項目,當然是底層的與項目無關。這部分代碼大部分是已有的,來自一個已經離開項目的同事,我寫了一部分。在此我只是記錄下而已。

    // 項目使用的是Angular2,這是一個service。有關Angular2的寫法我不做說明。 import { Injectable } from '@angular/core';@Injectable() export class WorkIndexedDBService {// 聲明一些屬性,name:數據庫名,version:數據庫版本// name和version發生變化,瀏覽器就會重新建一個新的indexedDBprivate name: string = 'test-docView';private version: number = 1;private db: any = null;constructor() { }// 打開并創建數據庫public open(): Promise<any> {return new Promise<any>((resolve, reject) => {// 打開indexedDBlet req = indexedDB.open(this.name, this.version);// 打開DB成功后的回調req.onsuccess = function(event) {this.db = event.target.result;resolve();}.bind(this); // 此處說明.bind(this),是為了把當前類的屬性和方法傳入req.onsuccess的這個function里。即:.bind(this)的this是指本類WorkIndexedDBService// 打開DB失敗后的回調req.onerror = reject;// 打開新的數據庫時,會回調此函數,改變name和version均會建立新的DB,所以都會發生此回調。req.onupgradeneeded = function(event) {// 如果版本升級要記得刪除舊的數據庫表再建立新的。this.db = event.target.result;let storeNames = this.db.objectStoreNames;if (storeNames && storeNames.length > 0) {for (let i = 0 ; i < storeNames.length ; i++) {this.db.deleteObjectStore(storeNames[i]);console.log('deleteObjectStore', storeNames[i]);}}// 創建數據庫表this.createViewDB();}.bind(this);});}// 關閉數據庫public close(): void {this.db.close();}// 刪除數據庫public deleteDB(): Promise<any> {return new Promise<any>((resolve, reject) => {// 先關閉連接再刪this.close();let req = indexedDB.deleteDatabase(this.name);req.onsuccess = function(event) {this.db = null;resolve();}.bind(this);req.onerror = reject;});}// 添加數據// 注意:使用事務來做操作比較快。public insert(storeName: string,data: any): Promise<any> {return new Promise<any>((resolve, reject) => {let transaction = this.db.transaction(storeName, 'readwrite');let store = transaction.objectStore(storeName);let req = store.add(data);req.onsuccess = function(event) {resolve(req.result);};req.onerror = reject;});}// 批量添加數據public batchInsert(storeName: string,data: any[]): Promise<any> {if (!data || data.length === 0) {return Promise.resolve();}let transaction = this.db.transaction(storeName, 'readwrite');let store = transaction.objectStore(storeName);return new Promise<null>((resolve, reject) => {data.forEach(row => store.add(row);});transaction.oncomplete = resolve;transaction.onerror = reject;}).catch((error) => {console.error('添加' + storeName + '表數據失敗', error);return Promise.reject(error);});}// 刪除數據public workdelete(storeName: string,keyValue: any): Promise<any> {return new Promise<any>((resolve, reject) => {let transaction = this.db.transaction(storeName, 'readwrite');let store = transaction.objectStore(storeName);let req = store.delete(keyValue);req.onsuccess = resolve;req.onerror = reject;});}// 清楚全部數據public clearAllData(): Promise<any> {let storeNameList: Array<string> = new Array<string>();let storeNames = this.db.objectStoreNames;if (storeNames && storeNames.length > 0) {for (let i = 0 ; i < storeNames.length ; i++) {storeNameList.push(storeNames[i]);}}return Promise.all(storeNameList.map((storeName) => {return this.clear(storeName);}));}// 清空數據public clear(storeName: string): Promise<any> {return new Promise<any>((resolve, reject) => {let transaction = this.db.transaction(storeName, 'readwrite');let store = transaction.objectStore(storeName);let req = store.clear();req.onsuccess = resolve;req.onerror = reject;});}// 更新數據public update(storeName: string,data: any): Promise<any> {return new Promise<any>((resolve, reject) => {let transaction = this.db.transaction(storeName, 'readwrite');let store = transaction.objectStore(storeName);let req = store.put(data);req.onsuccess = resolve;req.onerror = reject;});}// 根據Key取得數據public selectByKey(storeName: string,keyValue: any): Promise<any> {return new Promise<any>((resolve, reject) => {let transaction = this.db.transaction(storeName, 'readonly');let store = transaction.objectStore(storeName);let req = store.get(keyValue);req.onsuccess = function() {resolve(req.result);}req.onerror = reject;});}// 根據索引取得數據public selectByIndex(storeName: string,indexName: string,indexValue: any): Promise<any[]> {return new Promise<any[]>((resolve, reject) => {let transaction = this.db.transaction(storeName, 'readonly');let store = transaction.objectStore(storeName);let index = store.index(indexName);let req = index.openCursor(indexValue);let result: any[] = new Array<any>();req.onsuccess = function(event) {let cursor = event.target.result;if (cursor) {result.push(cursor.value);cursor.continue();} else {resolve(result);}}req.onerror = reject;});}// 批量合并數據public batchMerge(storeName: string,data: any[],delFlagColName?: string,delFlagColName2?: string): Promise<any> {if (!data || data.length === 0) {return Promise.resolve();}let transaction = this.db.transaction(storeName, 'readwrite');let store = transaction.objectStore(storeName);return new Promise<null>((resolve, reject) => {data.forEach(row => {let keyPath = store.keyPath;let keyValue;if (typeof keyPath === 'string') {keyValue = row[keyPath];} else {keyValue = new Array();keyPath.forEach(key => {keyValue.push(row[key]);});}store.delete(keyValue);} else {store.put(row);}});transaction.oncomplete = resolve;transaction.onerror = reject;}).catch((error) => {console.error('更新' + storeName + '表數據失敗', error);return Promise.reject(error);});}// 數據庫初始化處理private createDB(): void {this.createConfigInfo();this.createStoreUserInfo();this.createStoreOrgInfo();this.createStoreUserOrgInfo();}// 創建系統配置表及索引private createConfigInfo(): void {let store = this.db.createObjectStore('ConfigInfo',{keyPath: 'key'});}// 創建用戶表及索引private createStoreUserInfo(): void {let store = this.db.createObjectStore('UserInfo',{keyPath: 'userId'});}// 創建組織表及索引private createStoreOrgInfo(): void {let store = this.db.createObjectStore('OrgInfo',{keyPath: 'orgId'});store.createIndex('parentOrgIdIndex',['parentOrgId', 'displayOrder'],{unique: false});}// 創建組織表及索引private createStoreUserOrgInfo(): void {let store = this.db.createObjectStore('UserOrgInfo',// S zhuruifei 2017-08-14 通訊錄數據結構變更{keyPath: 'personRoleId'}// E zhuruifei 2017-08-14 通訊錄數據結構變更);store.createIndex('orgIdIndex','orgId',{unique: false});}// 創建稿件瀏覽記錄表private createViewDB(): void{let store = this.db.createObjectStore('viewedDoc',{keyPath: 'docId'});store.createIndex('viewedDoc','docId',{unique: true});}// 批量查詢稿件瀏覽信息judgeIfWatched(storeName: string,data: any[]):Promise<any>{if (!data || data.length === 0) {return Promise.resolve();}return Promise.all(data.map((data)=> {return this.selectByKey(storeName,data.docId).then((res)=> {if(res&&res.docId) {data.viewed = "1";}return Promise.resolve();})})).catch((error) => {console.error(error);return Promise.reject(error);});}// 清除30天前的數據cleanViewDB(){this.open().then(()=>{// 通過IDBDatabase得到IDBTransactionlet transaction = this.db.transaction('viewedDoc', 'readonly');// 通過IDBTransaction得到IDBObjectStorelet objectStore = transaction.objectStore("viewedDoc");// 打開游標,遍歷customers中所有數據objectStore.openCursor().onsuccess = function(event) {let cursor = event.target.result;if (cursor) {let key = cursor.key;let rowData = cursor.value;var time1 = new Date(rowData.lastViewTime);var time2 = new Date();if(Math.abs(time2.getTime() - time1.getTime())>2592000000){// 清除三十天前的數據this.workdelete('viewedDoc',cursor.key);}cursor.continue();}}.bind(this);})} }

    感謝您看到了這里,這里是結尾。如果對您有幫助,我深感欣慰。自己給自己做廣告,不犯法吧?歡迎關注WeChat公眾號

    **微信公眾號: 耐撕程序員

    有資源

    有想法

    有技術貼

    隨手掃一掃

    不吃虧不上當

    大家一起天天向上

    歡迎掃碼關注相互交流**

    總結

    以上是生活随笔為你收集整理的IndexedDB使用(基本函数封到Angular2的service里)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 成年人三级网站 | 成人免费视频观看视频 | 中文字幕五区 | 性高潮久久久久久久久久 | 强开小受嫩苞第一次免费视频 | julia在线播放88mav | 日韩精品一区二区在线视频 | 四色网址 | 无限资源日本好片 | 99热热热热 | 中文字幕在线视频播放 | 在线观看视频二区 | 91国在线观看 | 亚洲经典久久 | 日本在线视频一区 | 毛片在线免费播放 | 麻豆视频网页 | 精品动漫一区 | 麻豆精品av | 亚洲国产一区二区三区在线观看 | 国产成人久久777777 | 日韩成人av网址 | 日韩久久久久久久久久久 | 老司机深夜福利影院 | 亚洲深夜福利 | 色妞视频| 欧美精品久久久久久久多人混战 | 色婷婷一区二区三区四区 | 夜夜爽夜夜操 | jizz国产在线观看 | 人妻洗澡被强公日日澡电影 | 91精品福利视频 | 亚洲色图13p | 国产69精品久久 | 少妇视频一区二区三区 | 神马午夜伦理影院 | 另类尿喷潮videofree | 国产日本在线播放 | 久草免费在线视频 | caopor在线视频 | 一区二区中文字幕在线观看 | 国产11页| 理论视频在线观看 | 五月天爱爱 | 精品国产黄 | 国产在线一区二区视频 | 99免费在线视频 | 亚洲春色在线观看 | 国产毛片精品国产一区二区三区 | 男女日批视频 | 国产精品国产精品国产专区蜜臀ah | 秋霞av在线 | 中日韩男男gay无套 人人草人人干 | wwwxxoo| 天天添天天操 | 亚洲综合av网 | 国产日产精品一区二区三区四区 | 99re6在线精品视频免费播放 | 美国毛片av| 亚洲电影在线看 | 黄色免费在线视频 | 国产jjizz一区二区三区视频 | 亚洲av少妇一区二区在线观看 | 天天摸夜夜操 | 久久国产一| 高清不卡一区 | 国产精品自产拍高潮在线观看 | 免费一区二区三区四区 | 国产欧美日韩三区 | 在线精品亚洲欧美日韩国产 | 免费国产黄色片 | 18岁免费观看电视连续剧 | 中文字幕理论片 | 五月天中文字幕av | 日本黄页网站 | 激情五月婷婷色 | 成人免费看aa片 | 麻豆免费观看视频 | 日韩美女毛片 | 一区二区精品视频在线观看 | 亚洲天堂av网 | 欧美一区二区三区久久 | 国精产品一二三区精华液 | 日韩av中文| 无码国产69精品久久久久网站 | 精品视频在线一区二区 | 天天透天天操 | 高清毛片aaaaaaaaa郊外 | 日韩毛片基地 | 在线观看你懂的视频 | 亚洲人人插 | 欧美在线观看不卡 | 青青欧美| 操操干 | 美女丝袜合集 | 欧美在线综合 | 在线国产中文字幕 | 色九九九| 成人免费av在线 |