Handle the three get cases
This commit is contained in:
parent
d6d4d51173
commit
dc10568917
1 changed files with 17 additions and 16 deletions
|
@ -17,26 +17,27 @@ module.exports = {
|
||||||
sync: {
|
sync: {
|
||||||
get (keys, callback) {
|
get (keys, callback) {
|
||||||
const storage = getStorage()
|
const storage = getStorage()
|
||||||
|
if (keys == null) return storage
|
||||||
|
|
||||||
if (keys === {} || keys === []) return {}
|
let defaults = {}
|
||||||
if (keys === null) return storage
|
switch (typeof keys) {
|
||||||
|
case 'string':
|
||||||
if (typeof keys === 'string') keys = [keys]
|
keys = [keys]
|
||||||
|
break
|
||||||
|
case 'object':
|
||||||
|
if (!Array.isArray(keys)) {
|
||||||
|
defaults = keys
|
||||||
|
keys = Object.keys(keys)
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (keys.length === 0 ) return {}
|
||||||
|
|
||||||
let items = {}
|
let items = {}
|
||||||
// ['foo'] or ['foo', 'bar'] or [{foo: 'bar'}]
|
|
||||||
keys.forEach(function (key) {
|
keys.forEach(function (key) {
|
||||||
if (typeof key === 'string') {
|
var value = storage[key]
|
||||||
items[key] = storage[key]
|
if (value == null) value = defaults[key]
|
||||||
}
|
items[key] = value
|
||||||
else {
|
|
||||||
const objKey = Object.keys(key)
|
|
||||||
if (!storage[objKey] || storage[objKey] === '') {
|
|
||||||
items[objKey] = key[objKey]
|
|
||||||
} else {
|
|
||||||
items[objKey] = storage[objKey]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
|
|
||||||
setTimeout(function () {
|
setTimeout(function () {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue