Universal Routing
리액트 universal routing은 간단한 미들웨어 스타일 라우터로 isomorphic JavaScript web apps과 single-page 애플리케이션을 위해 제작 되었습니다. 각각의 라우터는 children:[ ] 속성이 있습니다. 이 속성을 사용하여 각각의 path에 따라 보여지는 컴포넌트를 랜더링 할 수 있습니다.
리액트 universal routing은 간단한 미들웨어 스타일 라우터로 isomorphic JavaScript web apps과 single-page 애플리케이션을 위해 제작 되었습니다. 각각의 라우터는 children:[ ] 속성이 있습니다. 이 속성을 사용하여 각각의 path에 따라 보여지는 컴포넌트를 랜더링 할 수 있습니다.
const routes = {
  path: '/admin'
  children: [
    {
      path: '/', action: () => {/* ... */}        // www.example.com/admin
    },
    {
      path: '/users',
      children: [
        {
          path: '/', action: () => {/* ... */}    // www.example.com/admin/users
        },
        {
          path: '/:id', action: () => {/* ... */} // www.example.com/admin/users/123
        }
      ]
    }
  ]
};
상품리스트 // items
 |_ 남녀선호도 // items/333/gender
 |_ 연령별선호도 // items/333/age
 |_ 국가별선호도 // items/333/nations
export default {
  path: '/items',
  children: [{
    path: '',
    children: [
      items,
    ],
  }, {
    path: '/:itemId',
    children: [
      gender,
      age,
      nations,
    ],
  }],
}
export default {
  path: '/gender',
  async action() {
    return {
      component:
      <ProductItemsLayout>
        <ItemsLayout />
      </ProductItemsLayout>,
    }
  },
}
class ItemsLayout extends React.Component<Props, any> {
  render() {
    const currentPath = this.props.currentPath || ''
    return (
      <div>
        <Navigation />
        {
        currentPath.endsWith('items') &&
          <Items />
        }
        {
        currentPath.endsWith('gender') &&
          <Gender />
        }
        {
          currentPath.endsWith('age') &&
          <Age />
        }
        {
          currentPath.endsWith('nations') &&
          <Nations/>
        }
      </div>
    )
  }
}
<ul>
  <li>
    <Link to={`/items`}>
      상품리스트
    </Link>
  </li>
  <li>
    <Link to={`/items/${ItemId}/gender`}>
      남녀선호도
    </Link>
  </li>
  <li>
    <Link to={`/items/${ItemId}/age`}>
      연령별선호도
    </Link>
  </li>
  <li>
    <Link to={`/items/${ItemId}/nations`}>
      국가별선호도
    </Link>
  </li>
</ul>
Comments
Post a Comment