0

0

React Native 中如何正确更新并显示异步获取的数据?

霞舞

霞舞

发布时间:2026-02-24 16:33:17

|

668人浏览过

|

来源于php中文网

原创

React Native 中如何正确更新并显示异步获取的数据?

在 React Native 函数组件中,直接修改普通变量无法触发 UI 更新;必须使用 useState 管理可变状态,并配合 useEffect 在组件挂载后发起异步请求,才能确保最新数据实时渲染。

react native 函数组件中,直接修改普通变量无法触发 ui 更新;必须使用 `usestate` 管理可变状态,并配合 `useeffect` 在组件挂载后发起异步请求,才能确保最新数据实时渲染。

在 React(包括 React Native)中,函数组件每次渲染都会重新执行其内部逻辑——这意味着你声明的普通变量(如 var companyData = "james")会在每次渲染时被重置为初始值。即使你在 axios.then() 中成功更新了该变量,这个赋值操作并不会通知 React 重新渲染组件,因此 JSX 中始终显示的是首次初始化的 "james",而非响应式更新后的数据。

要解决这个问题,核心在于两点:
用状态(state)替代普通变量:使用 useState 创建响应式状态,确保数据变化能驱动 UI 重绘;
在合适的时机发起副作用:使用 useEffect 并传入空依赖数组 [],保证异步请求仅在组件首次挂载后执行(等效于类组件中的 componentDidMount)。

以下是修正后的完整示例:

Img.Upscaler
Img.Upscaler

免费的AI图片放大工具

下载
import React, { useState, useEffect } from 'react';
import { View, Text } from 'react-native';
import axios from 'axios';

function Home(props) {
  // ✅ 使用 useState 声明响应式状态,默认值为 "james"
  const [companyData, setCompanyData] = useState('james');

  // ✅ 使用 useEffect 在组件挂载后发起请求
  useEffect(() => {
    axios
      .post('https://...', {
        // 注意:原代码中 headers 和 auth 的位置有误,应统一放在 config 对象中
        withCredentials: true,
        headers: {
          'Cache-Control': 'no-cache, no-store, must-revalidate',
          Pragma: 'no-cache',
          Expires: 0,
        },
        auth: {
          username: '',
          password: '',
        },
        data: {
          action: 'asdf',
        },
      })
      .then((response) => {
        // ✅ 通过 setCompanyData 触发状态更新和组件重渲染
        setCompanyData(response.data);
        console.log('Fetched company data:', response.data);
      })
      .catch((error) => {
        console.error('Failed to fetch company data:', error);
      });
  }, []); // ? 空依赖数组 → 仅执行一次

  return (
    <View>
      <Text>{companyData}</Text>
    </View>
  );
}

export default Home;

? 关键注意事项:

  • 不要在渲染过程中直接调用 setState(如在 return 前同步调用),否则会引发无限循环或警告;务必将其置于 useEffect 或事件处理器中。
  • 原始代码中 axios.post 的参数结构存在错误:headers、auth、data 应统一作为 config 对象的属性传入(见上方修复示例),否则可能被忽略或导致请求失败。
  • 首次渲染显示默认值是正常行为:UI 先显示 "james",随后 useEffect 执行并更新状态,触发第二次渲染展示新数据——这是 React 的标准响应式流程,无需额外处理。若需加载态提示,可扩展为 const [companyData, setCompanyData] = useState(null) 并配合条件渲染(如 companyData ? {companyData} : Loading...)。
  • 如需保存非响应式、不触发重渲染的值(如定时器 ID、DOM 引用),请使用 useRef,但绝不可用于驱动 UI 变化

遵循这一模式,即可确保异步数据准确、可靠地反映在 React Native 界面上。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

246

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

866

2024.03.01

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

552

2023.09.20

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3926

2024.08.14

Golang 性能优化专题:提升应用效率
Golang 性能优化专题:提升应用效率

《Golang 性能优化专题》聚焦 Go 应用在高并发与大规模服务中的性能问题,从 profiling、内存分配、Goroutine 调度、GC 机制到 I/O 与锁竞争逐层分析。结合真实案例讲解定位瓶颈的方法与优化策略,帮助开发者建立系统化性能调优思维,在保证代码可维护性的同时显著提升服务吞吐与稳定性。

0

2026.02.24

Golang 面试题精选:高频问题与解答
Golang 面试题精选:高频问题与解答

Golang 面试题精选》系统整理企业常见 Go 技术面试问题,覆盖语言基础、并发模型、内存与调度机制、网络编程、工程实践与性能优化等核心知识点。每道题不仅给出答案,还拆解背后的设计原理与考察思路,帮助读者建立完整知识结构,在面试与实际开发中都能更从容应对复杂问题。

1

2026.02.24

Golang 运行与部署实战:从本地到云端
Golang 运行与部署实战:从本地到云端

《Golang 运行与部署实战》围绕 Go 应用从开发完成到稳定上线的完整流程展开,系统讲解编译构建、环境配置、日志与配置管理、容器化部署以及常见运维问题处理。结合真实项目场景,拆解自动化构建与持续部署思路,帮助开发者建立可靠的发布流程,提升服务稳定性与可维护性。

3

2026.02.24

Golang 疑难杂症解决指南:常见问题排查与优化
Golang 疑难杂症解决指南:常见问题排查与优化

《Golang 疑难杂症解决指南》聚焦开发过程中常见却棘手的问题,从并发模型、内存管理、性能瓶颈到工程化实践逐步拆解。通过真实案例与调试思路,帮助开发者定位问题根因,建立系统化排查方法。不只给出答案,更强调分析路径与工具使用,让你在复杂 Go 项目中具备持续解决问题的能力。

0

2026.02.24

Golang 入门学习路线:从零基础到上手开发
Golang 入门学习路线:从零基础到上手开发

Golang 入门路线涵盖从零到上手的核心路径:首先打牢基础语法与切片等底层机制;随后攻克 Go 的灵魂——接口设计与 Goroutine 并发模型;接着通过 Gin 框架与 GORM 深入 Web 开发实战;最后在微服务与云原生工具开发中进阶,旨在培养具备高性能并发处理能力的后端工程师。

0

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.4万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号