zoukankan      html  css  js  c++  java
  • React高阶函数组件(HOC)

    方式一:Layout 作为一个高阶组件
    components/MyLayout.js
    import Header from './Header';
    
    const layoutStyle = {
      margin: 20,
      padding: 20,
      border: '1px solid #DDD'
    };
    
    const withLayout = Page => {
      return () => (
        <div style={layoutStyle}>
          <Header />
          <Page />
        </div>
      );
    };
    
    export default withLayout;
    
    pages/index.js
    import withLayout from '../components/MyLayout';
    
    const Page = () => <p>Hello Next.js</p>;
    
    export default withLayout(Page);
    
    pages/about.js
    import withLayout from '../components/MyLayout';
    
    const Page = () => <p>This is the about page</p>;
    
    export default withLayout(Page);
    方式二:Page content 作为一个 prop
    components/MyLayout.js
    import Header from './Header';
    
    const layoutStyle = {
      margin: 20,
      padding: 20,
      border: '1px solid #DDD'
    };
    
    const Layout = props => (
      <div style={layoutStyle}>
        <Header />
        {props.content}
      </div>
    );
    
    export default Layout;
    
    pages/index.js
    import Layout from '../components/MyLayout.js';
    
    const indexPageContent = <p>Hello Next.js</p>;
    
    export default function Index() {
      return <Layout content={indexPageContent} />;
    }
    
    pages/about.js
    import Layout from '../components/MyLayout.js';
    
    const aboutPageContent = <p>This is the about page</p>;
    
    export default function About() {
      return <Layout content={aboutPageContent} />;
    }
    

    .

  • 相关阅读:
    博主简介
    P1005 矩阵取数游戏
    P2051 [AHOI2009]中国象棋
    P1070 道路游戏
    P2577 [ZJOI2005]午餐
    P1169 [ZJOI2007]棋盘制作
    P1273 有线电视网
    P2467 [SDOI2010]地精部落
    P2331 [SCOI2005]最大子矩阵
    P2216 [HAOI2007]理想的正方形
  • 原文地址:https://www.cnblogs.com/crazycode2/p/13360812.html
Copyright © 2011-2022 走看看