refactor(home): 重构首页配置和路由处理
- 修改首页路由动态加载逻辑 - 优化滑动导航组件中的菜单处理 - 调整 Vuex store 中的 mods 数据处理方式 - 重构 main.js 中的 HomePage 配置
This commit is contained in:
@@ -55,7 +55,7 @@ const createRoutes = (config = {}) => {
|
|||||||
{path: '/dv', name: '数据大屏入口', component: () => import('../views/dvIndex')},
|
{path: '/dv', name: '数据大屏入口', component: () => import('../views/dvIndex')},
|
||||||
{path: '/v', name: 'Home', component: () => import('../views/home'), children: [
|
{path: '/v', name: 'Home', component: () => import('../views/home'), children: [
|
||||||
{path:'/',name:'mainEntry', component:()=>import('../views/mainEntry'),children:[
|
{path:'/',name:'mainEntry', component:()=>import('../views/mainEntry'),children:[
|
||||||
{name: "工作台", path: "${home}", component: () => import('${homePage}')},
|
{name: "${home}", path: "${home}", component: () => import('${homePage}')},
|
||||||
${routes.filter(e => ![sign, home].includes(e.name)).map(e => {
|
${routes.filter(e => ![sign, home].includes(e.name)).map(e => {
|
||||||
// 解构每个路由的属性,用于生成路由配置
|
// 解构每个路由的属性,用于生成路由配置
|
||||||
const {name, label, esm} = e
|
const {name, label, esm} = e
|
||||||
|
|||||||
@@ -39,12 +39,12 @@ export default {
|
|||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters(['mods']),
|
...mapGetters(['mods']),
|
||||||
navs: v => [v.$HomePage,...v.sortList(v.menuList)],
|
navs: v => [v.$HomePage, ...v.sortList(v.menuList)],
|
||||||
menuPath() {
|
menuPath() {
|
||||||
console.log(this.$route.name)
|
const mods = [this.$HomePage, ...this.mods]
|
||||||
let paths = [], current = this.mods?.find(e => e.name == this.$route.name)
|
let paths = [], current = mods?.find(e => e.component == this.$route.name)
|
||||||
const findParent = id => {
|
const findParent = id => {
|
||||||
let menu = this.mods?.find(e => e.id == id)
|
let menu = mods?.find(e => e.id == id)
|
||||||
if (menu) {
|
if (menu) {
|
||||||
paths.push(menu.id)
|
paths.push(menu.id)
|
||||||
if (!!menu.parentId) findParent(menu.parentId)
|
if (!!menu.parentId) findParent(menu.parentId)
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ Vue.use(appComp);
|
|||||||
Vue.config.productionTip = false;
|
Vue.config.productionTip = false;
|
||||||
Vue.prototype.$cdn = "https://cdn.cunwuyun.cn"
|
Vue.prototype.$cdn = "https://cdn.cunwuyun.cn"
|
||||||
Vue.prototype.$request = axios
|
Vue.prototype.$request = axios
|
||||||
Vue.prototype.$HomePage = {name: '工作台', label: '工作台', component: extra.homePage || 'console', id: "/v/console", path: '/v/console', style: "iconfont iconNav_Dashborad"}
|
const home = extra.homePage || 'console'
|
||||||
|
Vue.prototype.$HomePage = {name: '工作台', label: '工作台', component: home, id: `/v/${home}`, path: `/v/${home}`, style: "iconfont iconNav_Dashborad"}
|
||||||
Object.keys(utils).map((e) => (Vue.prototype[e] = utils[e]));
|
Object.keys(utils).map((e) => (Vue.prototype[e] = utils[e]));
|
||||||
const loadPage = () => new Vue({router, store, render: h => h(App)}).$mount("#app")
|
const loadPage = () => new Vue({router, store, render: h => h(App)}).$mount("#app")
|
||||||
let theme = null
|
let theme = null
|
||||||
|
|||||||
@@ -9,12 +9,8 @@ Vue.use(Vuex)
|
|||||||
|
|
||||||
export default new Vuex.Store({
|
export default new Vuex.Store({
|
||||||
state: {
|
state: {
|
||||||
homePage: {}
|
|
||||||
},
|
},
|
||||||
mutations: {
|
mutations: {
|
||||||
setHomePage(state, home) {
|
|
||||||
state.homePage = home
|
|
||||||
},
|
|
||||||
signOut(state, flag) {
|
signOut(state, flag) {
|
||||||
const base = extra.base || ""
|
const base = extra.base || ""
|
||||||
if (flag) {
|
if (flag) {
|
||||||
@@ -35,7 +31,6 @@ export default new Vuex.Store({
|
|||||||
getters: {
|
getters: {
|
||||||
//后台数据库中的应用集合,在本工程中不一定存在
|
//后台数据库中的应用集合,在本工程中不一定存在
|
||||||
mods: state => [
|
mods: state => [
|
||||||
state.homePage,
|
|
||||||
state.user.info?.menuSet?.map(e => ({route: e.id, ...e, label: e.name}))
|
state.user.info?.menuSet?.map(e => ({route: e.id, ...e, label: e.name}))
|
||||||
].flat().filter(Boolean)
|
].flat().filter(Boolean)
|
||||||
},
|
},
|
||||||
|
|||||||
Reference in New Issue
Block a user