成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

如何存儲(chǔ) React 組件的數(shù)據(jù)

Stardustsky / 1166人閱讀

摘要:四靜態(tài)的方式靜態(tài)方法和屬性也許是最少使用的靜下來,我知道他們不是真正在下的一個(gè)機(jī)制,大多數(shù)是因?yàn)樗麄儧]有被頻繁使用。但是訪問就必須要應(yīng)用場(chǎng)景靜態(tài)方法和屬性是很少被使用,主要被用來定義工具方法或者特定類型的所有組件。

主要講解這幾個(gè)部分:state、store、static、this、module-global data

前言

隨著 React 和 Redux 的到來,一個(gè)共同的問題被問到:

我應(yīng)該將數(shù)據(jù)保存在 Redux Store 中呢?還是應(yīng)該保存成本地 state?

其實(shí)這個(gè)問題是說的不完整( 或者原文說的太簡(jiǎn)單 ),因?yàn)槟隳茉诮M件中存儲(chǔ)數(shù)據(jù)的方式還有兩種:static 和 this.(其實(shí)就是靜態(tài)數(shù)據(jù),還是類的實(shí)例數(shù)據(jù))

讓我們來依次討論一下,你應(yīng)該在什么時(shí)候使用它們。

一、本地 state ( Local state )

ps:下面翻譯的時(shí)候?qū)?local state => 直接翻譯成 state 吧,對(duì)于 state 其實(shí)的作用域是與組件掛鉤的,直接翻譯成本地 state 其實(shí)是不準(zhǔn)確的。

當(dāng) React 在第一次被介紹的時(shí)候,我們就知道state。我們知道一個(gè)很重要的事情,就是當(dāng) state 的值改變的時(shí)候?qū)⒂|發(fā)組件的 re-render(重新渲染)。

這個(gè) state 也能傳遞給子組件,子組件中通過 props 來獲取傳遞的數(shù)據(jù),這就允許你能夠?qū)⒛愕慕M件分為:smart data-components(智能數(shù)據(jù)組件)and dumb presentational-components (填鴨式組件)。

這里有一個(gè)使用 state 來編寫的 counter app(計(jì)數(shù) APP):

import React from "react"

class App extends React.Component {
  constructor(props) {
    super(props)
    this.state = {
      counter: 0
    }
    this.addOne = this.addOne.bind(this)
  }
  
  addOne() {
    this.setState({
      counter: this.state.counter + 1
    })
  }
  
  render() {
    return (
      
{ this.state.counter }
) } } export default App

你的數(shù)據(jù)( counter 的值 )是存儲(chǔ)在 App 組件中,也能向下傳遞給子組件。

& 應(yīng)用場(chǎng)景

假如 counter 數(shù)據(jù)在你的 app 中是很重要的,以及這個(gè)數(shù)據(jù)會(huì)存儲(chǔ)下來用于其他組件,那么你將不希望使用 state 來保存這個(gè)值。

這最好的實(shí)踐是處理用戶接口 (UI, User Interface) 的狀態(tài)數(shù)據(jù)。比如:使用一個(gè) 交互組件 去填寫表單,這時(shí)候使用 state 是不錯(cuò)的選擇。

另外的例子,就是在 UI 交互相關(guān)的數(shù)據(jù)中使用,比如你將在一個(gè)列表中記錄當(dāng)前選中的 tab (選項(xiàng)卡)的狀態(tài),你就能存儲(chǔ)一個(gè) state。

在你選擇 state 的使用時(shí)機(jī),也能夠這樣考慮:你存儲(chǔ)的數(shù)據(jù)是否會(huì)在其他組件中使用。如果一個(gè)值是只有一個(gè)組件(或者也許只有一個(gè)子組件),這時(shí)使用 state 來保持這個(gè)值(或者說狀態(tài))都是安全的。

總結(jié):保持 UI 狀態(tài)和暫時(shí)的數(shù)據(jù)(比如:表單的輸入),能夠使用 state。

二、Redux store

隨著發(fā)展,每個(gè)人開始選擇單向數(shù)據(jù)流, 我們選擇 Redux。

對(duì)于 Redux,我們將獲得一個(gè)全局的 store。這個(gè) store 將綁定在一個(gè)最高等級(jí)的組件中,然后將 App 的數(shù)據(jù)流入所有的子組件(其實(shí)整個(gè) App 就已經(jīng)是這個(gè)最高等級(jí)組件的子組件了)。你能 connect 全局 store,使用:connect wrap 和 mapStateToProps 方法.

首先,人們就將任何事情都交給了 Redux store。比如:Users, modals, forms, sockets...,主要你知道的。

下面是一個(gè)和之前相同的計(jì)數(shù) App,然后使用了 Redux。主要需要注意的是 counter 數(shù)據(jù),使用 mapStateToProps 映射了數(shù)據(jù),并且使用 connect 方法包裹組件,this.state.counter 現(xiàn)在就變成了 this.props.counter,然后這個(gè)值就是通過全局 store 獲取的,這個(gè)全局 store 將值傳遞給當(dāng)前組件的 props。(如果想知道具體,我在 React.js 模式的文章中有介紹原理)。

import React from "react"
import { connect } from "react-redux"
import Actions from "./Actions.js"

class App extends React.Component {
  constructor(props) {
    super(props)
    this.addOne = this.addOne.bind(this)
  }
  
  addOne() {
    this.props.dispatch(Actions.addOne())
  }
  
  render() {
    return (
      
{ this.props.counter }
) } } const mapStateToProps = store => { return { counter: store.counter } } export default connect(mapStateToProps)(App)

現(xiàn)在當(dāng)你點(diǎn)擊按鈕的時(shí)候,通過一個(gè) action => dispatched 使全局 store 更新。然后這個(gè)數(shù)據(jù)通過外層組件傳遞到當(dāng)前組件。

值得注意的是:當(dāng) props 被更新的時(shí)候,這也將觸發(fā)組件的 re-render(重新渲染)=> 這與你更新 state 的時(shí)候一樣。

& 應(yīng)用場(chǎng)景

對(duì)于 Redux store 是很好的保持了除 UI 狀態(tài)數(shù)據(jù)外的應(yīng)用狀態(tài)。有一個(gè)不錯(cuò)的例子,比如用戶的登錄狀態(tài)。對(duì)于在在登錄狀態(tài)改變的同時(shí),多數(shù)組件需要訪問這個(gè)數(shù)據(jù)信息做出響應(yīng)。這些組件(至少有一個(gè)被渲染)將需要重新渲染與更新的信息。

Redux 觸發(fā)事件在你需要跨組件或者跨路由的情況下是很有用的。比如有一個(gè)登錄彈框,當(dāng)你的 App 中有多個(gè)按鈕點(diǎn)擊都將觸發(fā)彈出它的時(shí)候。而不是在你需要渲染這個(gè)彈框的多個(gè)地方做判斷,你能通過一個(gè)頂層的 App 組件去使用 Redux action 去觸發(fā)它并且修改 store 的值。

總結(jié):你想將跨組件的保持?jǐn)?shù)據(jù)的時(shí)候能夠使用 store。

三、this.

在 React 的開發(fā)中,使用 this 來保存數(shù)據(jù)的場(chǎng)景很少。人們經(jīng)常忘記了 React 使用的是 JavaScript 的 ES2015 的語法。任何你能夠用 JavaScript 做的事情,你都能在 React 做(這也是我非常喜歡 React 的原因呢 ^0^ freedom)。

下面的例子依然是一個(gè)計(jì)數(shù)應(yīng)用,與之前的例子有點(diǎn)類似。

import React from "react"

class App extends React.Component {
  constructor(props) {
    super(props)
    this.counter = 0
    this.addOne = this.addOne.bind(this)
  }
  
  addOne() {
    this.counter += 1
    this.forceUpdate()
  }
  
  render() {
    return (
      
{ this.counter }
) } } export default App

我們是在組件中使用 this 存儲(chǔ) counter 變量的值,并且使用 forceUpdate() 方法來觸發(fā)組件的重新渲染。這是因?yàn)闆]有任何的 state 和 props 修改,因此沒有自動(dòng)觸發(fā)重新渲染機(jī)制。

這個(gè)例子實(shí)際上不應(yīng)該使用 this。如果你發(fā)現(xiàn)你必須使用 forceUpdate() 才能滿足需求,你可能代碼哪里出了問題。如果想值修改的時(shí)候自動(dòng)觸發(fā)重新渲染,你應(yīng)該使用 state 或者 props/Redux store(其實(shí)嚴(yán)格一點(diǎn)來說,作者這里的表述是不清的,其實(shí)重新渲染與 Redux 并無關(guān)系,本質(zhì)上就是 props 的更新流入組件)。

& 應(yīng)用場(chǎng)景

使用 this 來保存數(shù)據(jù)的時(shí)候,能夠在改變的時(shí)候不需要去觸發(fā)重新渲染的場(chǎng)景。比如:sockets 是很好的一個(gè)使用 this 保存數(shù)據(jù)的場(chǎng)景。

import React from "react"
import { Socket } from "phoenix"

class App extends React.Component {
  componentDidMount() {
    this.socket = new Socket("http://localhost:4000/socket")
    this.socket.connect()
    this.configureChannel("lobby")
  }
  
  componentWillUnmount() {
    this.socket.leave()
  }
  
  configureChannel(room) {
    this.channel = this.socket.channel(`rooms:${room}`)
    this.channel.join()
      .receive("ok", () => {
        console.log(`Succesfully joined the ${room} chat room.`)
      })
      .receive("error", () => {
        console.log(`Unable to join the ${room} chat room.`)
      })
  }
  
  render() {
    return (
      
My App
) } } export default App

大多數(shù)人們沒有他們之前一直在使用 this 定義方法。放你定義 render(),你實(shí)際上是:this.prototype.render = function () { },但是這在 ES2015 的 class 語法機(jī)制下是隱式的。

總結(jié):在不需要數(shù)據(jù)改變的時(shí)候去觸發(fā)重新渲染機(jī)制的時(shí)候,能夠使用 this 去保存數(shù)據(jù)。

四、Static(靜態(tài)的方式)

靜態(tài)方法和屬性也許是最少使用的(靜下來,我知道他們不是真正在 class 下的一個(gè)機(jī)制),大多數(shù)是因?yàn)樗麄儧]有被頻繁使用。但是他們不是很復(fù)雜。如果你用過 PropTypes,你就定義了一個(gè) static 屬性。

下面有兩份代碼塊實(shí)際上是長(zhǎng)得一樣的。人們經(jīng)常使用的方式是第一種,第二種是你能使用 static 關(guān)鍵字來定義。

class App extends React.Component {
  render() {
    return (
{ this.props.title }
) } } App.propTypes = { title: React.PropTypes.string.isRequired }
class App extends React.Component {
  static propTypes {
    title: React.PropTypes.string.isRequired
  }
  
  render() {
    return (
{ this.props.title }
) } }

正如你看到的,static 并不復(fù)雜。他們是一種另外的方式去聲明一個(gè)類的值。這主要的不同是 static 不要像 this 那樣去實(shí)例化一個(gè)類再去訪問值。

class App extends React.Component {
  constructor() {
    super()
    this.prototypeProperty = {
      baz: "qux"
    }
  }
  static staticProperty = {
    foo: "bar"
  };
  
  render() {
    return (
My App
) } } const proto = new App(); const proto2 = proto.prototypeProperty // => { baz: "qux" } const stat = App.staticProperty // => { foo: "bar" }

在這個(gè)例子中,你能看獲取 staticProperty 的值,我們只組要直接通過類名去訪問,而不是實(shí)例后。但是訪問 proto.prototypeProperty 就必須要 new App().

& 應(yīng)用場(chǎng)景

靜態(tài)方法和屬性是很少被使用,主要被用來定義工具方法或者特定類型的所有組件。

propTypes 是一個(gè)工具例子,比如一個(gè) Button 組件,每一個(gè)按鈕的渲染都需要相似的值。

另外個(gè)案例就是如果你關(guān)注獲取的數(shù)據(jù)。如果你是使用 GraphQL 或者 Falcor,你能具體描述需要服務(wù)端返回什么數(shù)據(jù)。這種方法你能不用接受大量組件不需要的數(shù)據(jù)。

class App extends React.Component {
  static requiredData = [
    "username",
    "email",
    "thumbnail_url"
  ]
  
  render() {
    return(
) } }

因此在例子中,在特殊組件請(qǐng)求數(shù)據(jù)之前,你能使用 App.requiredData 快速獲取必要的 query 的值。

總結(jié):你也許幾乎不會(huì)使用 static 來保存數(shù)據(jù)。

五、其他方式...

其實(shí)是有另一個(gè)選擇,我沒有在標(biāo)題中說明,因?yàn)槟悴粦?yīng)該這樣做:你可以存儲(chǔ)在一個(gè)全局變量,然后通過一個(gè)文件進(jìn)行導(dǎo)出。

這是一個(gè)特別的場(chǎng)景,然后大多數(shù)情況下你不應(yīng)該這樣做。

import React from "react"

let counter = 0

class App extends React.Component {
  constructor(props) {
    super(props)
    this.addOne = this.addOne.bind(this)
  }
  
  addOne() {
    counter += 1
    this.forceUpdate()
  }
  
  render() {
    return (
      
{ counter }
) } } export default App

你能夠看到和使用 this 是類似的,除了使用的是一個(gè)全局的變量。

如果你需要跨組件的共享數(shù)據(jù)以及保存一個(gè)全局變量,大多數(shù)更好的是使用 Redux store。

總結(jié):不要使用全局變量。

原文出自:https://medium.freecodecamp.com/where-do-i-belong-a-guide-to-saving-react-component-data-in-state-store-static-and-this-c49b335e2a00#.yvhqqxdkh

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/92358.html

相關(guān)文章

  • 從設(shè)計(jì)角度看 Redux

    摘要:協(xié)調(diào)狀態(tài)的這三個(gè)方面是前端開發(fā)的重要組成部分,對(duì)這項(xiàng)任務(wù)有不同程度的支持。這使得保持高度統(tǒng)一。的真正威力到目前為止,看上去只是的輔助工具。在的術(shù)語中這稱之為派發(fā)動(dòng)作。撤銷重做流行的撤銷重做功能需要系統(tǒng)級(jí)規(guī)劃。 想閱讀更多優(yōu)質(zhì)文章請(qǐng)猛戳GitHub博客,一年百來篇優(yōu)質(zhì)文章等著你! 你知道 Redux 真正的作用遠(yuǎn)不止?fàn)顟B(tài)管理嗎? 你是否想要了解 Redux 的工作原理? 讓我們深入研究 ...

    fantix 評(píng)論0 收藏0
  • 【全棧React】第19天: 用Redux進(jìn)行數(shù)據(jù)管理

    摘要:歸約器函數(shù)負(fù)責(zé)返回應(yīng)用當(dāng)前全局狀態(tài)的表示形式。當(dāng)我們?cè)诖鎯?chǔ)上發(fā)送操作時(shí)將使用應(yīng)用的當(dāng)前狀態(tài)和導(dǎo)致狀態(tài)更新的操作來調(diào)用此歸約器函數(shù)。回到我們的歸約器我們可以檢查的動(dòng)作類型并采取適當(dāng)?shù)牟襟E創(chuàng)建下一個(gè)狀態(tài)。我們將處理動(dòng)作創(chuàng)造者中歸約器的副作用。 本文轉(zhuǎn)載自:眾成翻譯譯者:iOSDevLog鏈接:http://www.zcfy.cc/article/3811原文:https://www.ful...

    glumes 評(píng)論0 收藏0
  • 對(duì)React-redux中connect方法理解

    摘要:應(yīng)用中唯一的狀態(tài)應(yīng)用的子組件例子方法來看下函數(shù)到底是如何將和組件聯(lián)系在一起的,注意到文檔中有這樣的一句話并不會(huì)改變它連接的組件,而是提供一個(gè)經(jīng)過包裹的組件。 關(guān)于React-redux Redux是React全家桶的重要一員,之前在知乎上也看到類似的提問:該如何通俗易懂的理解Redux? Redux是JavaScript的狀態(tài)容器,Redux的概念簡(jiǎn)單明了: 1. 應(yīng)用中所有的狀...

    Bryan 評(píng)論0 收藏0
  • 快速了解 React Hooks 原理

    摘要:使用該對(duì)象,可以跟蹤屬于組件的各種元數(shù)據(jù)位。調(diào)用你的組件這意味著它知道存儲(chǔ)的元數(shù)據(jù)對(duì)象。下一次渲染會(huì)發(fā)生什么需要重新渲染組件由于之前已經(jīng)看過這個(gè)組件,它已經(jīng)有了元數(shù)據(jù)關(guān)聯(lián)。 為了保證的可讀性,本文采用意譯而非直譯。 想閱讀更多優(yōu)質(zhì)文章請(qǐng)猛戳GitHub博客,一年百來篇優(yōu)質(zhì)文章等著你! 我們大部分 React 類組件可以保存狀態(tài),而函數(shù)組件不能? 并且類組件具有生命周期,而函數(shù)組件卻不能...

    Hydrogen 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<