Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
hello uni-app x
提交
11d3afa6
H
hello uni-app x
项目概览
DCloud
/
hello uni-app x
通知
5995
Star
90
Fork
162
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
18
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
H
hello uni-app x
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
18
Issue
18
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
11d3afa6
编写于
7月 06, 2024
作者:
DCloud-WZF
💬
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: 优化 pages.json 数据结构
上级
fdbfd8f5
变更
2
展开全部
显示空白变更内容
内联
并排
Showing
2 changed file
with
1058 addition
and
1884 deletion
+1058
-1884
pages/tabBar/generateMenu.uts
pages/tabBar/generateMenu.uts
+27
-12
target-pages.json
target-pages.json
+1031
-1872
未找到文件。
pages/tabBar/generateMenu.uts
浏览文件 @
11d3afa6
import { pages } from '@/target-pages.json'
import { pages, groups } from '@/target-pages.json'
type Group = {
id : string,
name : string,
children : (Group | null)[] | null
}
type PageGroup = {
type PageGroup = {
id : string,
id : string,
name : string,
name : string,
index : number
| null
index : number
}
}
type Page = {
type Page = {
path : string,
path : string,
style : UTSJSONObject,
style : UTSJSONObject,
group ?:
PageGroup[]
| null
group ?:
string
| null
}
}
export type MenuItem = {
export type MenuItem = {
...
@@ -22,22 +28,31 @@ export type MenuItem = {
...
@@ -22,22 +28,31 @@ export type MenuItem = {
export function generateMenu(tabBarType : string) : (MenuItem | null)[] {
export function generateMenu(tabBarType : string) : (MenuItem | null)[] {
let res : (MenuItem | null)[] = []
let res : (MenuItem | null)[] = []
const tabBarPages = JSON.parse<Page[]>(JSON.stringify(pages))!.filter((page : Page) : boolean => page.path.startsWith(tabBarType) && hasPageGroup(page.group))
const tabBarPages = JSON.parse<Page[]>(JSON.stringify(pages))!.filter((page : Page) : boolean => page.path.startsWith(tabBarType) && hasPageGroup(page.group))
const groupTree = JSON.parse<(Group | null)[]>(JSON.stringify(groups))
tabBarPages.forEach(page => {
tabBarPages.forEach(page => {
let menuItemArr : (MenuItem | null)[] = res
let menuItemArr : (MenuItem | null)[] = res
let currentMenu : MenuItem | null = null
let currentMenu : MenuItem | null = null
const lastGroup = page.group![page.group!.length - 1]
const groupIndexList = page.group!.split(',').map((index : string) : number => parseInt(index))
let currentGroups : (Group | null)[] | null = groupTree
const pageGroups : PageGroup[] = []
groupIndexList.forEach((groupIndex, index) => {
if (index > 0) {
pageGroups.push({ id: currentGroups![groupIndex]!.id, name: currentGroups![groupIndex]!.name, index: groupIndex } as PageGroup)
}
currentGroups = currentGroups![groupIndex]!.children
})
const lastGroup = pageGroups[pageGroups.length - 1]
let hasPageGroup = false
let hasPageGroup = false
if (page.path.endsWith(camelToDash(lastGroup.name)) && page
.group!
.length > 1) {
if (page.path.endsWith(camelToDash(lastGroup.name)) && page
Groups
.length > 1) {
hasPageGroup = true
hasPageGroup = true
page
.group!
.pop()
page
Groups
.pop()
}
}
const groupLength = page
.group!
.length
const groupLength = page
Groups
.length
page
.group!
.forEach((group, groupIndex) => {
page
Groups
.forEach((group, groupIndex) => {
const { index, id, name } = group
const { index, id, name } = group
const validIndex = i
sNumber(index) ? index! : menuItemArr.length
const validIndex = i
ndex
fillMenuArrayWithNull(menuItemArr, validIndex)
fillMenuArrayWithNull(menuItemArr, validIndex)
if (menuItemArr[validIndex] == null) {
if (menuItemArr[validIndex] == null) {
...
@@ -57,7 +72,7 @@ export function generateMenu(tabBarType : string) : (MenuItem | null)[] {
...
@@ -57,7 +72,7 @@ export function generateMenu(tabBarType : string) : (MenuItem | null)[] {
}
}
})
})
if (hasPageGroup) {
if (hasPageGroup) {
const pageIndex =
isNumber(lastGroup.index) ? lastGroup.index! : currentMenu!.pages.length
const pageIndex =
lastGroup.index
fillPageArrayWithNull(currentMenu!.pages, pageIndex)
fillPageArrayWithNull(currentMenu!.pages, pageIndex)
if (currentMenu!.pages[pageIndex] == null) {
if (currentMenu!.pages[pageIndex] == null) {
currentMenu!.pages[pageIndex] = page
currentMenu!.pages[pageIndex] = page
...
@@ -72,7 +87,7 @@ export function generateMenu(tabBarType : string) : (MenuItem | null)[] {
...
@@ -72,7 +87,7 @@ export function generateMenu(tabBarType : string) : (MenuItem | null)[] {
return removeNullItem(res)
return removeNullItem(res)
}
}
function hasPageGroup(value :
PageGroup[]
| null) : boolean {
function hasPageGroup(value :
string
| null) : boolean {
// #ifdef APP-ANDROID
// #ifdef APP-ANDROID
return value !== null
return value !== null
// #endif
// #endif
...
...
target-pages.json
浏览文件 @
11d3afa6
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录