首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >本机本地数据备份

本机本地数据备份
EN

Stack Overflow用户
提问于 2021-09-27 02:26:33
回答 2查看 342关注 0票数 0

我在训练反应本地人。我想弄清楚如何在本地保存数据。

我有一个待办事项清单,并选择分配给这个任务的人.

例如,我希望保存添加的任务,以便在停止并重新启动应用程序时保留这些任务。我正在考虑使用异步存储,所以我这样做了:

const storeData =异步(任务) => {尝试{等待AsyncStorage.setItem('key',任务)} catch (e) { // lance une }}

但它似乎不起作用。

这是我为这个页面编写的所有代码。你能帮我把我的代码工作,并向我解释的行为,在这个过程中的功能?

谢谢。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import React, {useState} from 'react';
import { KeyboardAvoidingView, Text, View, TextInput, TouchableOpacity, Keyboard, ScrollView } from 'react-native';
import Task from '../../Task';
import SelectDropdown from 'react-native-select-dropdown'
import styles from "../../../assets/styles"

export default function Trucs() {
  const [task, setTask] = useState();
  const [taskItems, setTaskItems] = useState([]);
  const users = ["Jibé", "Charly"]

  const handleAddTask = () => {
    Keyboard.dismiss();
    setTaskItems([...taskItems, task])
    setTask(null);
  }

  const storeData = async (task) => {
    try {
      await AsyncStorage.setItem('key', task)
    } catch (e) {
      // lance une erreur
    }
  }

  const completeTask = (index) => {
    let itemsCopy = [...taskItems];
    itemsCopy.splice(index, 1);
    setTaskItems(itemsCopy)
    storeData(task)
  }
  
  return (
    <View style={styles.wrap}>
      {/* Added this scroll view to enable scrolling when list gets longer than the page */}
      <ScrollView
        contentContainerStyle={{
          flexGrow: 1
        }}
        keyboardShouldPersistTaps='handled'
      >
      {/* Today's Tasks */}
      <View style={styles.tasksWrapper}>
        <Text style={styles.sectionTitle}>Trucs à faire</Text>
          {/* This is where the tasks will go! */}
          {
            taskItems.map((item, index) => {
              return (
                <TouchableOpacity key={index}  onPress={()  => completeTask(index)}>
                    <View>
                        <Task text={item}/>
                        <SelectDropdown
                          data={users}
                          onSelect={(selectedItem, index) => {
                            console.log(selectedItem, index)
                          }}
                          buttonTextAfterSelection={(selectedItem, index) => {
                            // text represented after item is selected
                            // if data array is an array of objects then return selectedItem.property to render after item is selected
                            return selectedItem
                          }}
                          rowTextForSelection={(item, index) => {
                            // text represented for each item in dropdown
                            // if data array is an array of objects then return item.property to represent item in dropdown
                            return item
                          }}/>
                    </View>                    
                </TouchableOpacity>
              )
            })
          }
      </View>        
      </ScrollView>
      {/* Write a task */}
      {/* Uses a keyboard avoiding view which ensures the keyboard does not cover the items on screen */}
      <KeyboardAvoidingView 
       // behavior={Platform.OS === "ios" ? "padding" : "height"}
        style={styles.writeTaskWrapper}
      >
        <TextInput style={styles.input} placeholder={'Rajouter un truc à faire'} value={task} onChangeText={text => setTask(text)} />
        <TouchableOpacity onPress={() => handleAddTask()}>
          <View style={styles.addWrapper}>
            <Text style={styles.addText}>+</Text>
          </View>
        </TouchableOpacity>
      </KeyboardAvoidingView>      
    </View>
  );
}
EN

回答 2

Stack Overflow用户

发布于 2021-09-27 02:55:12

我觉得您没有正确地获取存储在AsyncStorage中的数据。看看我的两个按键存储和检索数据的函数。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  const storeData = async (key, value) => {
    try {
      await AsyncStorage.setItem(key, value);
    } catch (error) {
      console.log(error);
    }
  };

  const getData = async (key) => {
    try {
      const data = await AsyncStorage.getItem(key);
      if (data !== null) {
        console.log(data);
        return data;
      }
    } catch (error) {
      console.log(error);
    }
  };

然后,您可以在想要获取存储元素的地方调用getData("yourKey")。

票数 0
EN

Stack Overflow用户

发布于 2021-09-27 03:01:17

这里有几点:

1- AsyncStorage.setItem()接受同时是字符串的键和值。所以您需要在您的await AsyncStorage.setItem('key', JSON.stringify(task))方法中执行storeData

2-您需要在组件挂载后读取数据,并使用类似于useEffect的方法将其放入状态,以便在重新启动应用程序后显示数据。例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
useEffect(() => {
  AsyncStorage.getItem('key').then((res) => {
    setTask(JSON.parse(res));
  })
} , [])
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69345056

复制
相关文章
ZooKeeper日志配置
ZooKeeper 使用 SLF4J 作为日志的抽象层,默认使用 Log4J 来做实际的日志工作。使用两层日志抽象看起来似乎是多余的。这里简要的说明如何来配置 Log4J,虽然 Log4J 非常灵活且功能强大,但是也有一些复杂,这里只是简要的介绍一下基本的用法。
smartsi
2019/11/26
4.6K0
Deployment滚动更新策略RollingUpdate
当需要升级Deployment中的Pod镜像或者配置时,可以使用滚动更新策略,避免出现服务中断或者数据丢失。滚动更新策略可以让新的Pod在替代旧的Pod之前先完成启动,这样就能保证服务的持续可用性。Kubernetes中Deployment对象提供了两种滚动更新策略:RollingUpdate和Recreate。
玖叁叁
2023/04/29
1.2K0
Deployment滚动更新策略Recreate
Recreate策略是另一种滚动更新策略,它会先删除旧的Pod,然后再创建新的Pod。在进行滚动更新时,所有的Pod都会被同时停止,然后全部替换为新的Pod。Recreate策略的优点是可以避免新旧Pod的共存问题,但会在升级期间中断服务。
玖叁叁
2023/04/29
5260
Log4J.xml配置详解
问题:当引用第三方jar的时候,第三方jar打印了很多不需要的日志。我们应该如何去除。
斯文的程序
2019/11/07
15.8K1
【程序源代码】Log4J 日志分割
“ 关键字:通过log4j实现日志文件按照日期和文件大小进行自动分割保存,实现日志备份和日志文件合理管理。”
程序源代码
2020/04/26
1.4K0
使用log4j配置不同文件输出不同内容
敲代码中很不注意写日志,虽然明白很重要。今天碰到记录日志,需要根据内容分别输出到不同的文件。 参考几篇文章: 感觉最详细:http://blog.csdn.net/azheng270/article/details/2173430/ 喜欢博客园的日志风格,第一篇参考文章就是它:http://www.cnblogs.com/alipayhutu/archive/2012/06/21/2558249.html 写好的模板,直接修改就可以,虽然不满足我的需求:http://blog.csdn.net/rsun1/
Ryan-Miao
2018/03/13
3K0
使用log4j配置不同文件输出不同内容
springmvc 项目完整示例06 日志–log4j 参数详细解析 log4j如何配置
日志信息的优先级从高到低有ERROR、WARN、 INFO、DEBUG,分别用来指定这条日志信息的重要程度;
noteless
2018/09/11
8680
RollingFileAppender选项及相应配置
Layout用来规定日志是以什么样的格式输出,需要输出哪些信息。Layout提供四种日志输出样式,如根据HTML样式、自由指定样式、包含日志级别与信息的样式和包含日志时间、线程、类别等信息的样式。 常见的Layout如下:
用户7718188
2021/10/08
1.8K0
log4j介绍以及使用教程
  Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接 口服务 器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。    Log4j由三个重要的组件构成:日志信息的优先级,日志信息的输出目的地,日志信息的输出格式。
阿豪聊干货
2018/08/09
5770
Log4j 学习笔记(四)log4j的配置文件
此节分享xml形式的log4j.properties。 1. 将日志输出到控制台 log4j.xml: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYP
青山师
2023/05/04
6370
log4j配置文件模版
   log4j.properties {.brush:xml;toolbar: .true; .auto-links: .false;} log4j.rootLogger=DEBUG, INFO, ERROR # 输出控制台 log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE.Threshold=INFO log4j.appender.CONSOLE.Target=System.out log4j.a
明哥的运维笔记
2019/01/30
2.7K0
Log4j 入门教程
Log4J 是 Apache 的一个开源项目,通过在项目中使用 Log4J,我们可以控制日志信息输出到控制台、文件、GUI 组件、甚至是数据库中。我们可以控制每一条日志的输出格式,通过定义日志的输出级别,可以更灵活的控制日志的输出过程。方便项目的调试。
Remember_Ray
2020/08/03
5250
kafka log4j日志级别修改,一天生成一个日志文件
这有什么问题呢,虽然说我们用一天一次的滚动日志,但是我们配置的DataPattern为小时级别的,所以只要每个小时有日志生成,那么每个小时都会生成日志,简单来说就是一个小时一个。
从大数据到人工智能
2022/01/19
8380
log4j.xml示例_log4j.xml示例配置
We can configure log4j using both property file as well as xml file. Today we will look into log4j.xml example and get the details of log4j.xml configuration.
用户7886150
2020/11/18
1.2K0
Java日志框架学习--上
每一种日志框架都有自己单独的API,要使用对应的框架就要使用对应的API,这就大大的增加了应用程序代码对于日志框架的耦合性。
大忽悠爱学习
2022/05/15
4770
Java日志框架学习--上
Java日志框架学习--JUL和Log4j--上
每一种日志框架都有自己单独的API,要使用对应的框架就要使用对应的API,这就大大的增加了应用程序代码对于日志框架的耦合性。
大忽悠爱学习
2022/11/30
6870
Java日志框架学习--JUL和Log4j--上
Log4j.properties配置文件详解「建议收藏」
Log4J的配置文件(Configuration File)就是用来设置记录器的级别、存放器和布局的,它可接key=value格式的设置或xml格式的设置信息。通过配置,可以创建出Log4J的运行环境。
全栈程序员站长
2022/11/11
16.9K0
spark stream配置log输出
在cluster模式下,spark-submit添加如下参数。两个--conf分别为driver和executor设置log4j的配置文件,--files将文件上传到集群
平凡的学生族
2020/06/23
1.9K0
log4j2配置文件properties配置_log4j2 配置详解
Log4j支持两种配置文件格式,一种是XML格式的文件,一种是properties(key=value)文件,其中properties格式的配置文件最为常用,其有一个固定的文件名log4j.properties,下面我们介绍使用properties文件做为配置文件的方法:
全栈程序员站长
2022/11/11
4.2K0
细说log4j
可能做过java项目的基本上都是用过log4j,它是用来做java日志的。比如我们做一个项目分为很多的模块,那我们怎么想要知道它什么时候启动了,这时候我们可以使用log4j标记某某模块启动了。 努力的人绝对不会成为落后的标兵,加油!废话不多说,进入log4j。 一、log4j简介 1.1、log4j概述   log for java(java日志)   Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器
用户1195962
2018/01/18
1.7K0
细说log4j

相似问题

RollingFileAppender - log4j,MaxBackUpIndex未生效

126

在DailyRollingFileAppender -log4j中使用MaxBackupIndex

10

Log4j和Logback FileAppender maxFileSize和maxBackupIndex

12

Log4j在使用RollingFileAppender、maxsize、maxbackupindex和close时发出

10

默认log4j策略

21
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文