Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
计算机应用开发
前端
Vuepress
提交
463625c7
V
Vuepress
项目概览
计算机应用开发
/
前端
/
Vuepress
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
Vuepress
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
463625c7
编写于
9月 09, 2018
作者:
U
ULIVZ
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat($theme-blog): add 'type' field to page data and more reasonable layout fallback
上级
0e34e2d9
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
10 addition
and
6 deletion
+10
-6
packages/@vuepress/plugin-blog/index.js
packages/@vuepress/plugin-blog/index.js
+10
-6
未找到文件。
packages/@vuepress/plugin-blog/index.js
浏览文件 @
463625c7
...
...
@@ -16,21 +16,22 @@ module.exports = (options, ctx) => ({
const
{
layoutComponentMap
}
=
ctx
const
{
pageEnhancers
=
[]
}
=
options
const
isLayoutExists
=
name
=>
layoutComponentMap
[
name
]
!==
undefined
const
getLayout
=
name
=>
isLayoutExists
(
name
)
?
name
:
'
Layout
'
const
getLayout
=
(
name
,
fallback
)
=>
isLayoutExists
(
name
)
?
name
:
fallback
const
isDirectChild
=
regularPath
=>
path
.
parse
(
regularPath
).
dir
===
'
/
'
const
enhancers
=
[
{
when
:
({
regularPath
})
=>
isDirectChild
(
regularPath
),
frontmatter
:
{
layout
:
getLayout
(
'
Page
'
)
}
frontmatter
:
{
layout
:
getLayout
(
'
Page
'
,
'
Layout
'
)
},
data
:
{
type
:
'
page
'
}
},
{
when
:
({
regularPath
})
=>
regularPath
===
'
/category.html
'
,
frontmatter
:
{
layout
:
getLayout
(
'
Category
'
)
}
frontmatter
:
{
layout
:
getLayout
(
'
Category
'
,
'
Page
'
)
}
},
{
when
:
({
regularPath
})
=>
regularPath
===
'
/tags.html
'
,
frontmatter
:
{
layout
:
getLayout
(
'
Tag
'
)
}
frontmatter
:
{
layout
:
getLayout
(
'
Tag
'
,
'
Page
'
)
}
},
{
when
:
({
regularPath
})
=>
regularPath
===
'
/
'
,
...
...
@@ -39,19 +40,22 @@ module.exports = (options, ctx) => ({
{
when
:
({
regularPath
})
=>
regularPath
.
startsWith
(
'
/_posts/
'
),
frontmatter
:
{
layout
:
getLayout
(
'
Post
'
),
layout
:
getLayout
(
'
Post
'
,
'
Page
'
),
permalink
:
'
/:year/:month/:day/:slug
'
}
},
data
:
{
type
:
'
post
'
}
},
...
pageEnhancers
]
enhancers
.
forEach
(({
when
,
data
=
{},
frontmatter
=
{}
})
=>
{
if
(
when
(
pageCtx
))
{
Object
.
assign
(
rawFrontmatter
,
frontmatter
)
Object
.
assign
(
pageCtx
,
data
)
}
})
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录