0.1.6 • Published 4 years ago
@rainbow_deer/layout v0.1.6
Layout
install
npm install rainbow_deer/layout
or
yarn add rainbow_deer/layout
usage
basic
import React from 'react'
import Layout from '@rainbow_deer/layout'
import { createHashHistory } from 'history'
import { HomeOutlined } from '@ant-design/icons'
export default () => {
const routeItems = [
{
path: '/home',
exact: true,
meta: {
tabFixed: true,
isCache: true,
icon: 'home',
name: '首页',
},
component: () => <div>home</div>,
},
{
path: '/test',
exact: true,
meta: {
isCache: true,
icon: 'success',
name: '测试页',
},
component: () => <div>test</div>,
},
]
return (
<div className='storybook__container'>
<Layout
proName='admin-demo'
// aliveControl={aliveControl}
routeItems={routeItems}
history={createHashHistory()}
username={'测试'}
onClickDrop={() => {
console.log('退出')
}}
>
<div>layout</div>
</Layout>
</div>
)
}
cache route
yarn add react-router-cache-route
or
npm install react-router-cache-route
import React from 'react'
import { Router, Redirect, Route } from 'react-router-dom'
import Layout from '@rainbow_deer/layout'
import { createHashHistory } from 'history'
import {
CacheRoute,
CacheSwitch,
refreshByCacheKey,
dropByCacheKey,
} from 'react-router-cache-route'
const aliveControl = {
dropByCacheKey,
refreshByCacheKey,
}
const Counter = () => {
let [count, setCount] = React.useState(0)
const handleAdd = () => setCount(++count)
return (
<>
<button onClick={handleAdd}>+</button>
{count}
</>
)
}
export default () => {
const history = createHashHistory()
const routeItems = [
{
path: '/home',
exact: true,
meta: {
tabFixed: true,
isCache: true,
icon: 'home',
name: '首页',
},
component: () => <div>home</div>,
},
{
path: '/test',
exact: true,
meta: {
isCache: true,
icon: 'success',
name: '测试页',
},
component: Counter,
},
]
const renderRoutes = () => {
let routes = []
const routeMap = (arr) => {
arr.forEach((route) => {
if (!route.meta.hidden) {
routes.push(
<CacheRoute // 替换Route => CacheRoute
when={() => !!route.meta.isCache} // 是否缓存
cacheKey={route.path} // 缓存key
key={route.path}
exact={route.exact}
path={route.path}
component={route.component}
/>
)
}
if (route.routes && route.routes.length) routeMap(route.routes)
})
}
routeMap(routeItems)
return routes
}
return (
<Router history={history}>
<CacheSwitch>
<Layout
logo={
''
}
proName={'admin'}
routeItems={routeItems}
username={'admin'}
history={history}
aliveControl={aliveControl}
>
{renderRoutes()}
</Layout>
</CacheSwitch>
</Router>
)
}
0.1.6
4 years ago