User 69e88e27
发布于:2026-04-11
to_markdown: true 标记需要导出的变量:{
"id": "content",
"type": "richtext",
"label": "正文内容",
"to_markdown": true
}
{
"settings": [
{
"id": "title",
"type": "text",
"label": "标题",
"to_markdown": true
},
{
"id": "summary",
"type": "textarea",
"label": "摘要",
"to_markdown": true
},
{
"id": "body",
"type": "richtext",
"label": "正文",
"to_markdown": true
},
{
"id": "cover_image",
"type": "image_picker",
"label": "封面图",
"to_markdown": true
}
]
}
| 类型分类 | 具体类型 | Markdown 输出行为 |
|---|---|---|
富文本类型 (RICH_TYPES) |
richtext, html |
通过 FragmentValue.to_markdown 转换 |
纯文本类型 (PLAIN_TEXT_TYPES) |
text, textarea, paragraph |
直接输出字符串 |
代码类型 (CODE_TYPES) |
code |
包裹为代码块,支持 language 指定语法 |
选项类型 (CHOICE_TYPES) |
select, radio, checkbox, link |
直接输出值 |
简单值类型 (SIMPLE_VALUE_TYPES) |
number, range, date, color, font_picker, color_background |
直接输出字符串 |
资源选择器 (PICKER_TYPES) |
image_picker, file_picker, video_picker, dam_picker |
生成 20 分钟有效期的前端访问地址 |
标签选择器 (TAG_PICKER_TYPE) |
tag_picker |
输出标签名称列表 |
to_markdown: true 的变量输出为:## {label}
{转换后的内容}
label 优先取 setting["label"],否则使用 id.humanize。<p>这是一段<strong>加粗</strong>的文本。</p>
## 正文
这是一段**加粗**的文本。
{
"id": "script",
"type": "code",
"label": "脚本代码",
"language": "javascript",
"to_markdown": true
}
## 脚本代码
```javascript
const x = 1;
#### 图片选择器
输出 Markdown 图片语法:
```markdown
## 封面图

## 附件
https://portal.example.com/signed-url?expires=...
## 标签
技术, 文档, 教程
# app/models/page/to_markdown.rb
PORTAL_URL_EXPIRES_IN = 20.minutes