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

資訊專欄INFORMATION COLUMN

React入門0x013: Context

mudiyouyou / 3081人閱讀

摘要:創(chuàng)建消費者是一個組件,包裹在其中的函數(shù)組件可以訪問到聲明時候傳入的,并且在的變動的時候,再次渲染。使用效果整個栗子修改主題

0x000 概述

Context就是全局state啦~~

0x001 問題

先上栗子,我們需要在Topbar中用到theme,但是theme必須從最外層傳入,所以必須從最外層傳入App,再傳入TopBar,這只傳遞了兩次,但是如果全部組件都需要theme呢?或者有一個非常深的組件需要theme,而中間的大部分組件都不需要theme呢?為了傳遞這個theme必須一層一層的傳遞下去,有點難受。

class TopBar extends React.Component {
    redder() {
        return 
{this.props.theme}
} } class App extends React.Component { render() { return
} } ReactDom.render( , document.getElementById("app") )
0x002 解決

Context可以解決這個問題,上栗子:

創(chuàng)建context

const ThemeContext = React.createContext("theme"); 

React.createContext創(chuàng)建了一個context,它返回一個對象,可以打印出來:


需要注意的是:

Consumer:消費者

Provider:提供者

創(chuàng)建提供者

class App extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            theme: "dark"
        }
    }

    render() {
        return (
            
                
                
            
        );
    }

    handleChangeTheme() {
        this.setState({
            theme: this.state.theme === "light" ? "dark" : "light"
        })
    }
}

ThemeContext.Provider是一個組件,value屬性提供的值在所有的Consumer中都可以訪問到,前提是必須包裹在Provider中。

創(chuàng)建消費者

class ThemedButton extends React.Component {

    render() {
        return 
            {
                (value) => 
{value}
}
} }

ThemeContext.consumer是一個組件,包裹在其中的函數(shù)組件可以訪問到ThemeContext.Provider聲明時候傳入的value,并且在ThemeContext.Providervalue變動的時候,再次渲染。

使用

ReactDom.render(
    ,
    document.getElementById("app")
)

效果

整個栗子:

import ReactDom from "react-dom"
import React from "react"

const ThemeContext = React.createContext("theme");

class ThemedButton extends React.Component {

    render() {
        return 
            {
                (value) => 
{value}
}
} } class App extends React.Component { constructor(props) { super(props); this.state = { theme: "dark" } } render() { return ( ); } handleChangeTheme() { this.setState({ theme: this.state.theme === "light" ? "dark" : "light" }) } } ReactDom.render( , document.getElementById("app") )

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

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

相關(guān)文章

  • es6基礎(chǔ)0x013:WeakSet

    摘要:概述和差不多,但是有一些不同只能存儲對象,不能存儲任意值不可迭代是弱引用,也就是如果沒有變量引用內(nèi)的值,很容易被回收初始化因為只能存儲對象,所以這里我想只能傳入類似對象數(shù)組之類的東西對象數(shù)組添加判斷是否已經(jīng)有了刪除弱引用特性后輸出,可以看到 0x000 概述 WeakSet和Set差不多,但是有一些不同: WeakSet只能存儲對象,不能存儲任意值 WeakSet不可迭代 We...

    trigkit4 評論0 收藏0
  • React入門系列 - 2 編寫第一個Hello world的React程序

    摘要:安裝必要的開發(fā)包安裝兩個包安裝編寫一個的首先我們編寫一個的組件但是這僅僅是一個組件,我們需要一個頁面來容納的組件。到這一步,需要準(zhǔn)備的東西已經(jīng)完成了。 2.1 采用create react app 編寫 create-react-app項目 [[點擊前往Github]](https://github.com/facebook/c... 是facebook推出的入門初始化項目,適合新手第...

    PingCAP 評論0 收藏0
  • React入門0x017: 函數(shù)組件

    摘要:概述函數(shù)組件其實就是一個函數(shù),一個函數(shù)。所以可以用來做一些快速的封裝,比如,一個組件的代碼太多,顯得咋亂,又沒有復(fù)雜到需要另起一個組件,可以用函數(shù)組件源碼這是標(biāo)題欄這是導(dǎo)航欄哈哈效果總結(jié)沒有多余的東西,對性能也有所提升哦 0x000 概述 函數(shù)組件其實就是一個函數(shù),一個render函數(shù)。 0x001 栗子 源碼 import React from react import Reac...

    weapon 評論0 收藏0
  • React 可視化開發(fā)工具 Shadow Widget 非正經(jīng)入門(之二:分離界面設(shè)計)

    摘要:本篇講解轉(zhuǎn)義標(biāo)簽投影定義,這幾項與如何分離界面設(shè)計有關(guān)。找一個替代品如上一篇非正經(jīng)入門之一所述,要克服漿糊的不利影響,要找一個替代品。本文完本專欄歷史文章介紹一項讓可以與抗衡的技術(shù)可視化開發(fā)工具非正經(jīng)入門之一三宗罪 本系列博文從 Shadow Widget 作者的視角,解釋該框架的設(shè)計要點。本篇講解轉(zhuǎn)義標(biāo)簽、json-x、投影定義,這幾項與 如何分離界面設(shè)計 有關(guān)。 ? 1. 找一個 ...

    Carl 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<