第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

向 JSX Element 變量添加額外的道具

向 JSX Element 變量添加額外的道具

Cats萌萌 2022-07-08 09:59:21
如何向作為道具傳遞的 JSX.Element 變量添加其他道具?首先我像這樣創(chuàng)建變量const leftIcon = <SmallIcon icon="note" color={colors.red} />然后它被傳遞給我的函數(shù)組件并像const ScreenHeader: React.FunctionComponent<ScreenHeaderProps> = ({  leftIcon = <></>,}) => {return (    <View>    <Header       leftComponent={leftIcon}    />  </View>)};如何在“l(fā)eftIcon”變量中添加額外的樣式道具,然后再將其用于 Header?
查看完整描述

2 回答

?
精慕HU

TA貢獻(xiàn)1845條經(jīng)驗(yàn) 獲得超8個(gè)贊

如果您以React現(xiàn)在的方式使用組件初始化變量(const leftIcon = <SmallIcon />),那么您將無(wú)法向props其中傳遞附加值。


這是一個(gè)可能的解決方案:


// make `LeftIcon` into a function so that you

// can use it in the following way: `<LeftIcon />`

const LeftIcon = (props) => (

  <div className="LeftIcon" onClick={() => {}} {...props}>

    <p>I am a left icon!</p>

    <p>Additional props: {JSON.stringify(props)}</p>

  </div>

);


const ScreenHeader = ({ leftComponent = null }) => {

  const CustomLeftComponent = leftComponent ? leftComponent : null;

  const greenComponent = CustomLeftComponent 

    ? <CustomLeftComponent style={{ color: "green" }} /> 

    : null;

  return (

    <div>

      <p>I am a screen header!</p>

      {greenComponent}

    </div>

  );

};


function App() {

  return (

    <div className="App">

      <ScreenHeader leftComponent={LeftIcon} />

      <hr />

      <ScreenHeader />

    </div>  

  );

}


ReactDOM.render(

  <App />,

  document.getElementById("app")

)

<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>

<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>

<div id="app"></div>


或者,您可以在內(nèi)部使用之前將附加信息傳遞props給組件:LeftIconScreenHeader


// make `LeftIcon` into a function so that you

// can use it in the following way: `<LeftIcon />`

const LeftIcon = (props) => (

  <div className="LeftIcon" onClick={() => {}} {...props}>

    <p>I am a left icon!</p>

    <p>Additional props: {JSON.stringify(props)}</p>

  </div>

);


const ScreenHeader = ({ leftComponent = null }) => {

  return (

    <div>

      <p>I am a screen header!</p>

      {leftComponent}

    </div>

  );

};


function App() {

  return (

    <div className="App">

      <ScreenHeader leftComponent={<LeftIcon style={{ color: "green" }} />} />

      <hr />

      <ScreenHeader />

    </div>  

  );

}


ReactDOM.render(

  <App />,

  document.getElementById("app")

)

<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>

<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>

<div id="app"></div>


查看完整回答
反對(duì) 回復(fù) 2022-07-08
?
皈依舞

TA貢獻(xiàn)1851條經(jīng)驗(yàn) 獲得超3個(gè)贊

您可以使用React.cloneElement添加額外的道具


const ScreenHeader: React.FunctionComponent<ScreenHeaderProps> = ({

  leftIcon = <></>,

}) => {


return (

    <View>

    <Header 

      leftComponent={React.cloneElement(leftIcon, {className: classes.myClass})}

    />

  </View>

)};


查看完整回答
反對(duì) 回復(fù) 2022-07-08
  • 2 回答
  • 0 關(guān)注
  • 194 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)