| | |
| | | // 设置 props默认值 作用就是将字段设置成配置的 |
| | | const propsDefault = { |
| | | label: propsConfig.label || 'name', |
| | | path: propsConfig.path || 'path', |
| | | path: 'code', |
| | | pathValue:propsConfig.path || 'path', |
| | | 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, |
| | | if (first) { |
| | | // 将 '/index' 替换为 '' |
| | | return oMenu[propsDefault.pathValue].replace('/index', '') |
| | | } else { |
| | | return oMenu[propsDefault.pathValue] |
| | | } |
| | | })(); |
| | | let code = (() => { |
| | | return oMenu[propsDefault.path] |
| | | })(); |
| | | // 将字符串分割成数组,以'?'作为分隔符 |
| | | let parts = path.split("?"); |
| | | // 如果数组的长度大于1,表示有'?',则取第一个元素的第一个部分,否则直接取整个字符串 |
| | | let bsValue = parts.length > 1 ? parts[0].split("=")[1] : path.split("=")[1]; |
| | | |
| | | if (bsValue ==='' || bsValue === undefined || bsValue === null ) { |
| | | bsValue = "UI"; |
| | | } |
| | | |
| | | //特殊处理组件 执行完这个 component 也就是精确到具体的文件了 views文件夹下面就是具体的页面代码 |
| | | let component = bsValue === 'UI' ? 'views/base/UIContentViewer' : `views/custom-ui/${bsValue}`, |
| | | name = oMenu[propsDefault.label], |
| | | icon = oMenu[propsDefault.icon], |
| | | children = oMenu[propsDefault.children], |
| | |
| | | //是否有子路由 |
| | | const isChild = children.length !== 0; |
| | | const oRouter = { |
| | | path: path, |
| | | path: code, |
| | | component(resolve) { |
| | | // 判断是否为首路由 |
| | | if (first) { |