| | |
| | | import {validatenull} from "@/util/validate"; |
| | | |
| | | let RouterPlugin = function () { |
| | | this.$router = null; |
| | | this.$store = null; |
| | |
| | | * first: 为了区分外界 调用formatRoutes 和 当前文件调用 formatRoutes |
| | | */ |
| | | formatRoutes: function (aMenu = [], first) { |
| | | // debugger; |
| | | const aRouter = [] |
| | | // 获取到全局配置中的 props |
| | | const propsConfig = this.$website.menu.props; |
| | | // 设置 props默认值 作用就是将字段设置成配置的 |
| | | const propsDefault = { |
| | | label: propsConfig.label || 'name', |
| | | path: propsConfig.path || 'path', |
| | | path: 'code', |
| | | code: 'code', |
| | | pathValue: 'pathValue', |
| | | icon: propsConfig.icon || 'icon', |
| | | children: propsConfig.children || 'children', |
| | | meta: propsConfig.meta || 'meta', |
| | |
| | | const oMenu = aMenu[i]; |
| | | // 这一块的赋值 也就是取到返回的值 |
| | | let path = (() => { |
| | | if (first) { |
| | | // 将 '/index' 替换为 '' |
| | | return oMenu[propsDefault.path].replace('/index', '') |
| | | } else { |
| | | return oMenu[propsDefault.path] |
| | | } |
| | | })(), |
| | | //特殊处理组件 执行完这个 component 也就是精确到具体的文件了 views文件夹下面就是具体的页面代码 |
| | | component = 'views' + path, |
| | | name = oMenu[propsDefault.label], |
| | | if (first) { |
| | | // 将 '/index' 替换为 '' |
| | | return oMenu[propsDefault.pathValue].replace('/index', '') |
| | | } else { |
| | | return oMenu[propsDefault.pathValue] |
| | | } |
| | | })(); |
| | | let code = (() => { |
| | | return oMenu[propsDefault.code] |
| | | })(); |
| | | |
| | | let component = ''; |
| | | let parts = ''; |
| | | |
| | | // 如果路径中存在 '?',则取问号前面部分给 parts |
| | | if (path.includes('?')) { |
| | | parts = path.split("?")[0]; |
| | | } else { |
| | | parts = path; // 不存在 '?' 整条路径就是 parts |
| | | } |
| | | if(validatenull(parts)){ |
| | | parts='UI'; |
| | | } |
| | | // 如果问号前面部分不在 ['ui', 'UI', 'base'] 中,则是自定义组件 |
| | | if (!['ui', 'UI', 'base','bs'].includes(parts) && parts.indexOf('views/')==-1) { |
| | | component = `views/custom-ui/${parts}`; |
| | | }else if (['UI', 'ui', 'base','bs'].includes(parts)) { |
| | | // 如果问号前面等于 UI、ui 则为UI引擎 |
| | | component = 'views/base/UIContentViewer'; |
| | | }else{ |
| | | component = `${parts}`; |
| | | } |
| | | |
| | | let name = oMenu[propsDefault.label], |
| | | icon = oMenu[propsDefault.icon], |
| | | children = oMenu[propsDefault.children], |
| | | meta = oMenu[propsDefault.meta] || {}; |
| | |
| | | //是否有子路由 |
| | | const isChild = children.length !== 0; |
| | | const oRouter = { |
| | | path: path, |
| | | path: '/' + code, |
| | | component(resolve) { |
| | | // 判断是否为首路由 |
| | | if (first) { |
| | |
| | | children: !isChild ? (() => { |
| | | if (first) { |
| | | // 这里的isURL判断,因为这个网站有使用 iframe。所以需要判断是否为网页链接 |
| | | if (!isURL(path)) oMenu[propsDefault.path] = `${path}/index`; |
| | | if (!isURL(path)) oMenu[propsDefault.pathValue] = `${path}/index`; |
| | | return [{ |
| | | component(resolve) { |
| | | require([`../${component}.vue`], resolve) |