在 AsyncStorage 中 setItem 的正确方法 [英] Right way to setItem in AsyncStorage

查看:105
本文介绍了在 AsyncStorage 中 setItem 的正确方法的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想在 AsyncStorage.getItem 中使用 AsyncStorage.setItem.如何以正确的方式做到这一点?

I want to use AsyncStorage.setItem inside AsyncStorage.getItem. How to do that in right way?

我的代码如下:

createVehicle: function (vehicle, cb) {
    AsyncStorage.getItem('vehicle')
    .then(json => {

        let vehicles = [];

        if (json) {
            vehicles = JSON.parse(json);
            let o_vehicle = filter(vehicles, {autralis_id: vehicle.autralis_id});
            if (o_vehicle.length > 0) {
                cb(o_vehicle[0].id);
                return;
            } else {
                vehicles.push(vehicle);
            }
        } else {
            vehicles.push(vehicle);
        }
        AsyncStorage.setItem('vehicle', JSON.stringify(vehicles), () => {
            cb(vehicle.id + 1)
        });
    }).done();
},

这是正确的做法吗?

推荐答案

我为 Storage 创建了一个服务,可以在需要时通过传递所需的参数在整个项目中使用它.看看:

I have created a service for Storage which can be used in the entire project as and when required by passing the required params. Have a look :

export default {
async setItem(key, value) {
    try {
        return await AsyncStorage.setItem(key, JSON.stringify(value));
    } catch (error) {
        // console.error('AsyncStorage#setItem error: ' + error.message);
    }
},
async getItem(key) {
    return await AsyncStorage.getItem(key)
        .then((result) => {
            if (result) {
                try {
                    result = JSON.parse(result);
                } catch (e) {
                    // console.error('AsyncStorage#getItem error deserializing JSON for key: ' + key, e.message);
                }
            }
            return result;
        });
},
async removeItem(key) {
    return await AsyncStorage.removeItem(key);
}
}

这是迄今为止我遇到的最佳实践.你也应该使用它.

This is by far the best practice I have come across till the date. You should use it too.

这篇关于在 AsyncStorage 中 setItem 的正确方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆