Как использовать async / await для получения значения из AsyncStorage в реагировать нативно с помощью функции - PullRequest
0 голосов
/ 16 января 2019

Я создал prefsManager.js - используйте для хранения и извлечения данных из AsyncStorage, но я столкнулся с проблемой, например, когда журнал печати возвращает всегда неопределенное значение, потому что это Async, но я хочу напечатать фактическое значение в журнале с помощью вызов функции.

import { AsyncStorage } from 'react-native';
import prefskey from '../utils/constants/prefskeys';

const setValue = async (key, value) => {
    await AsyncStorage.setItem(key, value);
}

const getValue = async (key) => {
    let value = '';
    try {
        value = await AsyncStorage.getItem(key) || 'none';
    } catch (error) {
        // Error retrieving data 
        console.log(error.message);
    }
    return value;
};

const prefsmanager = {
    setValue,
    getValue
}
export default prefsmanager; 

Я использовал это в своем Home.js, когда нажимаю кнопку, я вызываю этот метод.

_handlePress() {

        await prefsManager.setValue(prefskey.username, this.state.username)

        console.log("username =>>", await prefsManager.getValue(prefskey.username)); 

     }

Ответы [ 3 ]

0 голосов
/ 16 января 2019
  1. Установить значение в хранилище
AsyncStorage.setItem('data','Read Data')
  1. Получить значение из хранилища
constructor(props) {
    super(props)       

    this.state = {};
    let self=this;

    //this function is called everytime , when you visit this screen.
    this.__didFocusSubscription = this.props.navigation.addListener('didFocus',payload => {
        AsyncStorage.getItem('data').then((value)=>{
            if(value==null){
                self.setState({count:'no data found'})
            }
            else{
                self.setState({count:value})
            }
        })
    });       
}
0 голосов
/ 16 января 2019

На самом деле, это похоже на localStorage в сети, но с небольшой разницей. при получении предмета он действует асинхронно. обратите внимание на ниже:

AsyncStorage.setItem('key', value);

Но в получении это как ниже:

AsyncStorage.getItem('key')
  .then( value => console.log(value) );
0 голосов
/ 16 января 2019

Вам нужно использовать ключевое слово async в вашей функции следующим образом.

    import { AsyncStorage } from 'react-native';
import prefskey from '../utils/constants/prefskeys';

const prefsnamager = {

    setValue: function (key, value) {
        AsyncStorage.setItem(key, value)
    },

    getValue: async (key) => {
        let value = '';
        try {
            value = await AsyncStorage.getItem(key) || 'none';
        } catch (error) {
            // Error retrieving data
            console.log(error.message);
        }
        return value;
    }
}
export default prefsnamager;

вызывающая функция

_handlePress = () => {
        prefsManager.setValue(prefskey.username, this.state.username)

        console.log("username =>>" , prefsManager.getValue(prefskey.username));

     }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...