摘要:簡(jiǎn)介離線存儲(chǔ),提供強(qiáng)大的封裝專業(yè)封裝給封裝類似類似接口如果你熟悉那一定會(huì)用使用類似的接口操作基于的瀏覽器端數(shù)據(jù)庫(kù)基于的瀏覽器端數(shù)據(jù)庫(kù)小型數(shù)據(jù)庫(kù),瀏覽器端基于風(fēng)格的接口,讓它非??蓯?ài)
查看原文
有些安全性不太重要的數(shù)據(jù),我不想花大力氣搞一臺(tái)服務(wù)器,再安裝mysql或者 monogdb,再寫點(diǎn)rest接口。這也太麻煩了,瀏覽器里本來(lái)就有很好用的數(shù)據(jù)庫(kù)。你為什么不嘗試一下呢?1. 客戶端存儲(chǔ)目前有兩個(gè)方案比較
方案 | 優(yōu)點(diǎn) | 缺點(diǎn) |
---|---|---|
localStorage | 簡(jiǎn)單易用,同步操作 | 存儲(chǔ)容量小,一般不超過(guò)10MB |
indexDB | 接口都是異步的,操作不便 | 容量比localStorage大 |
如果要使用localStorage,那么存儲(chǔ)量比較小。如果是用indexDB,那么最好找點(diǎn)開(kāi)源庫(kù),直接封裝友好的API, 來(lái)方便我們使用indexDB。
下面介紹一些很好用的的庫(kù)。
2. 簡(jiǎn)介 2.1. localForage離線存儲(chǔ), 提供強(qiáng)大的API封裝IndexedDB,WebSQL,localStorage
12073 star
https://github.com/localForag...
localforage.setItem("key", "value", function (err) { // if err is non-null, we got an error localforage.getItem("key", function (err, value) { // if err is non-null, we got an error. otherwise, value is the value }); });2.2. Dexie.js
專業(yè)封裝 IndexedDB
3040 star
https://github.com/dfahlander...
const db = new Dexie("MyDatabase"); // Declare tables, IDs and indexes db.version(1).stores({ friends: "++id, name, age" }); // Find some old friends await db.friends .where("age") .above(75) .toArray(); // or make a new one await db.friends.add({ name: "Camilla", age: 25, street: "East 13:th Street", picture: await getBlob("camilla.png") });2.3. zangodb
給HTML5 IndexedDB 封裝類似mongodb類似接口, 如果你熟悉mongodb, 那一定會(huì)用zangodb
688 star
https://github.com/erikolson1...
let db = new zango.Db("mydb", { people: ["age"] }); let people = db.collection("people"); let docs = [ { name: "Frank", age: 20 }, { name: "Thomas", age: 33 }, { name: "Todd", age: 33 }, { name: "John", age: 28 }, { name: "Peter", age: 33 }, { name: "George", age: 28 } ]; people.insert(docs).then(() => { return people.find({ name: { $ne: "John" }, age: { $gt: 20 } }).group({ _id: { age: "$age" }, count: { $sum: 1 } }).project({ _id: 0, age: "$_id.age" }).sort({ age: -1 }).forEach(doc => console.log("doc:", doc)); }).catch(error => console.error(error));2.4. JsStore
使用類似 sql的接口操作 indexDB
74 star
https://github.com/ujjwalgupt...
var value = { column1: value1, column2: value2, column3: value3, ... columnN: valueN }; connection.insert({ into: "TABLE_NAME", values: [Value], //you can insert multiple values at a time }).then(function(rowsAffected) { if (rowsAffected > 0) { alert("Successfully Added"); } }).catch(function(error) { alert(error.message); });2.5. minimongo
基于localstorage的瀏覽器端mongodb數(shù)據(jù)庫(kù)
697 star
https://github.com/mWater/min...
// Require minimongo var minimongo = require("minimongo"); var LocalDb = minimongo.MemoryDb; // Create local db (in memory database with no backing) db = new LocalDb(); // Add a collection to the database db.addCollection("animals"); doc = { species: "dog", name: "Bingo" }; // Always use upsert for both inserts and modifies db.animals.upsert(doc, function() { // Success: // Query dog (with no query options beyond a selector) db.animals.findOne({ species:"dog" }, {}, function(res) { console.log("Dog"s name is: " + res.name); }); });2.6. pouchdb
基于indexDB的CouchDB-style瀏覽器端數(shù)據(jù)庫(kù)
10599 star
https://github.com/pouchdb/po...
var db = new PouchDB("dbname"); db.put({ _id: "dave@gmail.com", name: "David", age: 69 }); db.changes().on("change", function() { console.log("Ch-Ch-Changes"); }); db.replicate.to("http://example.com/mydb");2.7. lowdb
小型json數(shù)據(jù)庫(kù),瀏覽器端基于localStorage, lodash風(fēng)格的接口,讓它非常可愛(ài)
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/107903.html
摘要:簡(jiǎn)介離線存儲(chǔ),提供強(qiáng)大的封裝專業(yè)封裝給封裝類似類似接口如果你熟悉那一定會(huì)用使用類似的接口操作基于的瀏覽器端數(shù)據(jù)庫(kù)基于的瀏覽器端數(shù)據(jù)庫(kù)小型數(shù)據(jù)庫(kù),瀏覽器端基于風(fēng)格的接口,讓它非??蓯?ài) 查看原文 有些安全性不太重要的數(shù)據(jù),我不想花大力氣搞一臺(tái)服務(wù)器,再安裝mysql或者 monogdb,再寫點(diǎn)rest接口。這也太麻煩了,瀏覽器里本來(lái)就有很好用的數(shù)據(jù)庫(kù)。你為什么不嘗試一下呢? 1. 客戶端存...
摘要:私有緩存就是用戶專享的,各級(jí)代理不能緩存的緩存。代表使用內(nèi)存中的緩存,則代表使用的是硬盤中的緩存,瀏覽器讀取緩存的順序?yàn)椤? 作為一名前端工作人員,前端的緩存知識(shí)是必須掌握的,因?yàn)橐粋€(gè)網(wǎng)站打開(kāi)網(wǎng)頁(yè)的速度直接關(guān)系到用戶體驗(yàn),用戶粘度,而提高網(wǎng)頁(yè)的打開(kāi)速度有很多方面需要優(yōu)化,其中比較重要的一點(diǎn)就是利用好緩存,緩存文件可以重復(fù)利用,還可以減少帶寬,降低網(wǎng)絡(luò)負(fù)荷。 1 緩存 緩存從宏觀上分為私有...
摘要:私有緩存就是用戶專享的,各級(jí)代理不能緩存的緩存。代表使用內(nèi)存中的緩存,則代表使用的是硬盤中的緩存,瀏覽器讀取緩存的順序?yàn)椤? 作為一名前端工作人員,前端的緩存知識(shí)是必須掌握的,因?yàn)橐粋€(gè)網(wǎng)站打開(kāi)網(wǎng)頁(yè)的速度直接關(guān)系到用戶體驗(yàn),用戶粘度,而提高網(wǎng)頁(yè)的打開(kāi)速度有很多方面需要優(yōu)化,其中比較重要的一點(diǎn)就是利用好緩存,緩存文件可以重復(fù)利用,還可以減少帶寬,降低網(wǎng)絡(luò)負(fù)荷。 1 緩存 緩存從宏觀上分為私有...
摘要:私有緩存就是用戶專享的,各級(jí)代理不能緩存的緩存。代表使用內(nèi)存中的緩存,則代表使用的是硬盤中的緩存,瀏覽器讀取緩存的順序?yàn)椤? 作為一名前端工作人員,前端的緩存知識(shí)是必須掌握的,因?yàn)橐粋€(gè)網(wǎng)站打開(kāi)網(wǎng)頁(yè)的速度直接關(guān)系到用戶體驗(yàn),用戶粘度,而提高網(wǎng)頁(yè)的打開(kāi)速度有很多方面需要優(yōu)化,其中比較重要的一點(diǎn)就是利用好緩存,緩存文件可以重復(fù)利用,還可以減少帶寬,降低網(wǎng)絡(luò)負(fù)荷。 1 緩存 緩存從宏觀上分為私有...
閱讀 1026·2021-11-23 09:51
閱讀 2344·2021-10-08 10:22
閱讀 2544·2021-09-29 09:35
閱讀 854·2021-09-22 15:20
閱讀 2859·2019-08-30 15:53
閱讀 2413·2019-08-30 13:55
閱讀 1097·2019-08-29 17:27
閱讀 2870·2019-08-29 17:26