Non-centralized router, where routes are configured in each component. the better way to config router!
npm install frontend-distribution-router
# OR
yarn add frontend-distribution-router
example.js:
export const routeConfig = {
path:"/example",
}
export default function Example() {
return (<h1>Example</h1>)
}
app.js:
import * as exampleModule from './example.vue'
import {genRanderFunction, pathChangeNotify} from 'frontend-distribution-router'
const randerFunction = genRanderFunction({
mode:'hash',
moduleList:[exampleModule],
defaultModule:exampleModule,
})
function App() {
const [componentList,setComponentListHook] = useState(randerFunction())
pathChangeNotify({mode:'hash',callback:()=>{
setComponentListHook(randerFunction())
}})
return (
<div>
{
componentList.map(View=>{
return (<View/>)
})
}
</div>
)
}
export default App;
example.vue:
export const routeConfig = {
path:'/example'
}
export default {
name: "example",
data: function () {
return {}
},
}
app.vue:
<component
v-for="component in componentList"
:key="component"
v-bind:is="component" />
import { markRaw } from 'vue'
import * as exampleModule from './example.vue'
import {genRanderFunction, pathChangeNotify} from 'frontend-distribution-router'
export default {
name: "example",
data: function () {
return {
componentList:[]
}
},
created: function () {
const randerFunction = genRanderFunction({
mode:'hash',
moduleList:[exampleModule],
defaultModule:exampleModule,
beforePush:({
module,
componentKey
})=>{
module[componentKey] = markRaw(module[componentKey])
}
})
this.componentList = randerFunction()
pathChangeNotify({mode:'hash',callback:()=>{
this.componentList = randerFunction()
}})
}
}
example.svelet:
// <script context="module">
export const routeConfig = {
path:"/example",
}
// </script>
app.svelet:
{#each componentList as component}
<svelte:component this={component} />
{/each}
import * as exampleModule from './example.svelet'
import {genRanderFunction, pathChangeNotify} from 'frontend-distribution-router'
const randerFunction = genRanderFunction({
mode:'hash',
moduleList:[exampleModule],
defaultModule:exampleModule,
})
let componentList = randerFunction()
pathChangeNotify({mode:'hash',callback:()=>{
componentList = randerFunction()
}})