亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

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

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

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

2 回答

?
精慕HU

TA貢獻1845條經驗 獲得超8個贊

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


這是一個可能的解決方案:


// 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>


或者,您可以在內部使用之前將附加信息傳遞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>


查看完整回答
反對 回復 2022-07-08
?
皈依舞

TA貢獻1851條經驗 獲得超3個贊

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


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

  leftIcon = <></>,

}) => {


return (

    <View>

    <Header 

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

    />

  </View>

)};


查看完整回答
反對 回復 2022-07-08
  • 2 回答
  • 0 關注
  • 189 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號