」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 狀態與道具:掌握 React Native 應用程式中的資料流

狀態與道具:掌握 React Native 應用程式中的資料流

發佈於2024-11-08
瀏覽:961

State and Props: Mastering Data Flow in Your React Native App

如果您是 React Native 或 React 新手,您一定会遇到过“state”和“props”这两个词。了解这两者对于开发动态且适应性强的移动应用程序至关重要。我们将在这篇博客文章中深入探讨 state 和 props,检查它们的差异,并学习如何有效处理 React Native 应用程序中的数据流。

什么是 State 和 Props?

状态

State 是一个内置对象,允许组件创建和管理自己的数据。它保存的信息可能会在组件的生命周期中发生变化。每当状态发生变化时,组件就会重新渲染以反映这些变化。

  • Mutable: 可以使用 setState(在类组件中)或 useState 钩子(在功能组件中)更改状态。
  • 组件本地: 状态是完全封装的并且是组件本地的。
  • 触发重新渲染:更新状态会导致组件重新渲染。

道具

Props 是属性的缩写,是只读组件。它们是传递到组件中的外部参数,类似于将参数传递到函数中的方式。

  • 不可变: Props 不能被接收它们的组件修改。
  • Passed Down from Parent: Props 从父组件传递到子组件。
  • 用于配置:它们配置组件并从外部控制其行为。

理解差异

特征 状态 道具
可变性 可变(可以随时间改变) 不可变(只读)
范围 组件本地 从父组件传递给子组件
目的 管理随时间变化的数据 使用外部数据配置组件
更新 更新时触发重新渲染 在父级中更改时不触发重新渲染

了解何时使用状态以及何时使用 props 是管理应用程序中数据流的关键。

为什么它们很重要?

  • 状态对于需要跟踪和响应用户输入、API 响应或其他动态数据的组件至关重要。
  • Props 允许组件通过接受动态数据和函数来重用,使您的代码更加模块化和可维护。

有效管理数据流

有效的数据流管理可确保您的应用程序行为可预测,并且更易于调试和维护。

1.单向数据流

React Native 使用单向数据流。数据通过 props 从父组件移动到子组件。这使得数据流更容易理解和调试。

2.提升状态

当多个组件需要访问同一条数据时,最好将状态提升到最近的共同祖先。这样,共享状态就可以通过 props 传递下去。

3.使用回调进行子与父的通信

为了允许子组件与父组件通信,您可以将函数(回调)作为 props 传递。然后子组件可以调用此函数将数据发送回父组件。

示例

让我们看一些代码示例来说明这些概念。

示例 1:使用 Props

父组件(App.js):

import React from 'react';
import { View } from 'react-native';
import Greeting from './Greeting';

const App = () => {
  return (
    
      
      
    
  );
};

export default App;

子组件(Greeting.js):

import React from 'react';
import { Text } from 'react-native';

const Greeting = (props) => {
  return Hello {props.name};
};

export default Greeting;

解释:

  • App 组件将 name 属性传递给 Greeting 组件。
  • Greeting 组件接收 props 并使用 props.name 来显示个性化消息。

示例 2:使用状态

计数器组件(Counter.js):

import React, { useState } from 'react';
import { View, Button, Text } from 'react-native';

const Counter = () => {
  const [count, setCount] = useState(0);

  return (
    
      You clicked {count} times
      
  );
};

export default Counter;

解释:

  • 我们使用 useState 钩子将 count 初始化为 0。
  • setCount函数更新状态。
  • 按下按钮时,计数递增,并且组件重新渲染以显示新计数。

示例 3:提升状态

父组件(TemperatureConverter.js):

import React, { useState } from 'react';
import { View } from 'react-native';
import TemperatureInput from './TemperatureInput';

const toCelsius = (fahrenheit) => ((fahrenheit - 32) * 5) / 9;
const toFahrenheit = (celsius) => (celsius * 9) / 5   32;

const TemperatureConverter = () => {
  const [temperature, setTemperature] = useState('');
  const [scale, setScale] = useState('c');

  const handleCelsiusChange = (temp) => {
    setScale('c');
    setTemperature(temp);
  };

  const handleFahrenheitChange = (temp) => {
    setScale('f');
    setTemperature(temp);
  };

  const celsius =
    scale === 'f' ? toCelsius(parseFloat(temperature)) : temperature;
  const fahrenheit =
    scale === 'c' ? toFahrenheit(parseFloat(temperature)) : temperature;

  return (
    
      
      
    
  );
};

export default TemperatureConverter;

子组件(TemperatureInput.js):

import React from 'react';
import { TextInput, Text } from 'react-native';

const scaleNames = {
  c: 'Celsius',
  f: 'Fahrenheit',
};

const TemperatureInput = ({ scale, temperature, onTemperatureChange }) => {
  return (
    
      Enter temperature in {scaleNames[scale]}:
      
    >
  );
};

export default TemperatureInput;

解释:

  • 共享状态温度和标度被提升到TemperatureConverter组件。
  • TemperatureInput 组件接收 props 并通过回调将更改传达回父级。

最佳实践

1.尽可能保持组件无状态

无状态组件更容易测试和调试。使用 props 将数据传递给它们。

2.最小化状态性

仅在必要时使用状态。太多有状态组件会使您的应用程序更难管理。

3.避免直接状态突变

永远不要直接改变状态。始终使用 setState 或 useState.

中的 updater 函数

4.使用 PropTypes 进行类型检查

使用 PropTypes 记录传递给组件的预期属性类型。

import PropTypes from 'prop-types';

Greeting.propTypes = {
  name: PropTypes.string.isRequired,
};

5.利用 Context API 获取全局状态

对于需要由不同嵌套级别的多个组件访问的数据,请考虑使用 Context API。

要避免的常见错误

  • 直接改变状态:
  // Incorrect
  this.state.count = this.state.count   1;

  // Correct
  this.setState({ count: this.state.count   1 });
  • 使用 Props 直接修改父状态:

子组件不应尝试直接修改 props 或父状态。使用回调。

结论

理解并有效管理状态和属性对于任何 React Native 开发人员来说都是至关重要的。通过掌握这些概念,您将能够构建不仅实用而且干净、高效且可维护的应用程序。

记住:

  • 状态适用于随时间变化的数据,并在组件内进行管理。
  • Props 用于在组件树中传递数据和函数。

花时间在项目中实践这些概念,您将看到开发工作流程的显着改进。

版本聲明 本文轉載於:https://dev.to/bharath_madhu/state-and-props-mastering-data-flow-in-your-react-native-app-336h?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在GO中構造SQL查詢時,如何安全地加入文本和值?
    在GO中構造SQL查詢時,如何安全地加入文本和值?
    在go中構造文本sql查詢時,在go sql queries 中,在使用conting and contement和contement consem per時,尤其是在使用integer per當per當per時,per per per當per. [&​​​​&&&&&&&&&&&&&&&默元組方...
    程式設計 發佈於2025-07-08
  • 版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    在時間戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源於遺留實現的關注,這些限制需要對當前的_timestamp功能進行特定的實現。 創建表`foo`( `Productid` int(10)unsigned not ...
    程式設計 發佈於2025-07-08
  • 如何簡化PHP中的JSON解析以獲取多維陣列?
    如何簡化PHP中的JSON解析以獲取多維陣列?
    php 試圖在PHP中解析JSON數據的JSON可能具有挑戰性,尤其是在處理多維數組時。 To simplify the process, it's recommended to parse the JSON as an array rather than an object.To do...
    程式設計 發佈於2025-07-08
  • 為什麼我的CSS背景圖像出現?
    為什麼我的CSS背景圖像出現?
    故障排除:CSS背景圖像未出現 ,您的背景圖像儘管遵循教程說明,但您的背景圖像仍未加載。圖像和样式表位於相同的目錄中,但背景仍然是空白的白色帆布。 而不是不棄用的,您已經使用了CSS樣式: bockent {背景:封閉圖像文件名:背景圖:url(nickcage.jpg); 如果您的html,cs...
    程式設計 發佈於2025-07-08
  • 如何在其容器中為DIV創建平滑的左右CSS動畫?
    如何在其容器中為DIV創建平滑的左右CSS動畫?
    通用CSS動畫,用於左右運動 ,我們將探索創建一個通用的CSS動畫,以向左和右移動DIV,從而到達其容器的邊緣。該動畫可以應用於具有絕對定位的任何div,無論其未知長度如何。 問題:使用左直接導致瞬時消失 更加流暢的解決方案:混合轉換和左 [並實現平穩的,線性的運動,我們介紹了線性的轉換。...
    程式設計 發佈於2025-07-08
  • PHP未來:適應與創新
    PHP未來:適應與創新
    PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。 引言在編程世界中,PHP一直是網頁開發的中流砥柱。作為一個從1994年就開始發展...
    程式設計 發佈於2025-07-08
  • 為什麼使用Firefox後退按鈕時JavaScript執行停止?
    為什麼使用Firefox後退按鈕時JavaScript執行停止?
    導航歷史記錄問題:JavaScript使用Firefox Back Back 此行為是由瀏覽器緩存JavaScript資源引起的。要解決此問題並確保在後續頁面訪問中執行腳本,Firefox用戶應設置一個空功能。 警報'); }; alert('inline Alert')...
    程式設計 發佈於2025-07-08
  • 如何使用Python有效地以相反順序讀取大型文件?
    如何使用Python有效地以相反順序讀取大型文件?
    在python 中,如果您使用一個大文件,並且需要從最後一行讀取其內容,則在第一行到第一行,Python的內置功能可能不合適。這是解決此任務的有效解決方案:反向行讀取器生成器 == ord('\ n'): 緩衝區=緩衝區[:-1] ...
    程式設計 發佈於2025-07-08
  • 人臉檢測失敗原因及解決方案:Error -215
    人臉檢測失敗原因及解決方案:Error -215
    錯誤處理:解決“ error:((-215)!empty()in Function Multultiscale中的“ openCV 要解決此問題,必須確保提供給HAAR CASCADE XML文件的路徑有效。在提供的代碼片段中,級聯分類器裝有硬編碼路徑,這可能對您的系統不准確。相反,OPENCV提...
    程式設計 發佈於2025-07-08
  • 表單刷新後如何防止重複提交?
    表單刷新後如何防止重複提交?
    在Web開發中預防重複提交 在表格提交後刷新頁面時,遇到重複提交的問題是常見的。要解決這個問題,請考慮以下方法: 想像一下具有這樣的代碼段,看起來像這樣的代碼段:)){ //數據庫操作... 迴聲“操作完成”; 死(); } ? > ...
    程式設計 發佈於2025-07-08
  • 為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
    為什麼不````''{margin:0; }`始終刪除CSS中的最高邊距?
    在CSS 問題:不正確的代碼: 全球範圍將所有餘量重置為零,如提供的代碼所建議的,可能會導致意外的副作用。解決特定的保證金問題是更建議的。 例如,在提供的示例中,將以下代碼添加到CSS中,將解決餘量問題: body H1 { 保證金頂:-40px; } 此方法更精確,避免了由全局保證金重置...
    程式設計 發佈於2025-07-08
  • 如何使用PHP將斑點(圖像)正確插入MySQL?
    如何使用PHP將斑點(圖像)正確插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call fil...
    程式設計 發佈於2025-07-08
  • 如何使用Depimal.parse()中的指數表示法中的數字?
    如何使用Depimal.parse()中的指數表示法中的數字?
    在嘗試使用Decimal.parse(“ 1.2345e-02”中的指數符號表示法表示的字符串時,您可能會遇到錯誤。這是因為默認解析方法無法識別指數符號。 成功解析這樣的字符串,您需要明確指定它代表浮點數。您可以使用numbersTyles.Float樣式進行此操作,如下所示:[&& && && ...
    程式設計 發佈於2025-07-08
  • Async Void vs. Async Task在ASP.NET中:為什麼Async Void方法有時會拋出異常?
    Async Void vs. Async Task在ASP.NET中:為什麼Async Void方法有時會拋出異常?
    在ASP.NET async void void async void void void void void void void的設計無需返回asynchroncon而無需返回任務對象。他們在執行過程中增加未償還操作的計數,並在完成後減少。在某些情況下,這種行為可能是有益的,例如未期望或明確...
    程式設計 發佈於2025-07-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3