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: {
|
||||
get (keys, callback) {
|
||||
const storage = getStorage()
|
||||
if (keys == null) return storage
|
||||
|
||||
if (keys === {} || keys === []) return {}
|
||||
if (keys === null) return storage
|
||||
|
||||
if (typeof keys === 'string') keys = [keys]
|
||||
let defaults = {}
|
||||
switch (typeof keys) {
|
||||
case 'string':
|
||||
keys = [keys]
|
||||
break
|
||||
case 'object':
|
||||
if (!Array.isArray(keys)) {
|
||||
defaults = keys
|
||||
keys = Object.keys(keys)
|
||||
}
|
||||
break;
|
||||
}
|
||||
if (keys.length === 0 ) return {}
|
||||
|
||||
let items = {}
|
||||
// ['foo'] or ['foo', 'bar'] or [{foo: 'bar'}]
|
||||
keys.forEach(function (key) {
|
||||
if (typeof key === 'string') {
|
||||
items[key] = storage[key]
|
||||
}
|
||||
else {
|
||||
const objKey = Object.keys(key)
|
||||
if (!storage[objKey] || storage[objKey] === '') {
|
||||
items[objKey] = key[objKey]
|
||||
} else {
|
||||
items[objKey] = storage[objKey]
|
||||
}
|
||||
}
|
||||
var value = storage[key]
|
||||
if (value == null) value = defaults[key]
|
||||
items[key] = value
|
||||
})
|
||||
|
||||
setTimeout(function () {
|
||||
|
|
Loading…
Add table
Reference in a new issue