diff --git a/demo.html b/demo.html
new file mode 100644
index 0000000..b48e7e9
--- /dev/null
+++ b/demo.html
@@ -0,0 +1,71 @@
+
+
+
+
+
+ Canvas Editor Iframe Demo
+
+
+
+ 父页面(同源)加载子页面 index.html(支持 ?filePath=URL)
+
+
+
+
+ 支持传入 JSON(完整编辑器数据)或纯文本(作为正文)。文件将以 blob: URL 形式传递,保证同源。
+
+
+
+
+
+
\ No newline at end of file
diff --git a/public/test.ocd b/public/test.ocd
new file mode 100644
index 0000000..2a3e9d9
--- /dev/null
+++ b/public/test.ocd
@@ -0,0 +1,539 @@
+{
+ "header": [
+ {
+ "value": "教材在线编辑器",
+ "size": 32,
+ "rowFlex": "center"
+ },
+ {
+ "value": "\n测试数据",
+ "size": 18,
+ "rowFlex": "center"
+ },
+ {
+ "value": "\n",
+ "type": "separator",
+ "width": 554
+ }
+ ],
+ "main": [
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "主诉:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "\n发热三天,咳嗽五天。",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "control",
+ "control": {
+ "conceptId": "1",
+ "type": "text",
+ "value": [],
+ "placeholder": "其他补充",
+ "prefix": "{",
+ "postfix": "}"
+ }
+ },
+ {
+ "value": "\n",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "现病史:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "\n患者于三天前无明显诱因,感冒后发现面部水肿,无皮疹,尿量减少,出现乏力,在外治疗无好转,现来我院就诊。\n",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "既往史:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "\n有糖尿病10年,有高血压2年,有",
+ "size": 16
+ },
+ {
+ "value": "传染性疾病",
+ "size": 16,
+ "color": "#FF0000"
+ },
+ {
+ "value": "1年。",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "control",
+ "control": {
+ "conceptId": "2",
+ "type": "select",
+ "value": [],
+ "code": null,
+ "placeholder": "有无",
+ "prefix": "{",
+ "postfix": "}",
+ "valueSets": [
+ {
+ "value": "有",
+ "code": "98175"
+ },
+ {
+ "value": "无",
+ "code": "98176"
+ },
+ {
+ "value": "不详",
+ "code": "98177"
+ }
+ ]
+ }
+ },
+ {
+ "value": "报告其他既往疾病。\n",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "流行病史:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "\n否认14天内接触过",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "hyperlink",
+ "url": "https://hufe.club/canvas-editor",
+ "valueList": [
+ {
+ "value": "新冠肺炎",
+ "size": 16,
+ "color": "#0000FF",
+ "underline": true
+ }
+ ]
+ },
+ {
+ "value": "确诊患者、疑似患者、无症状感染者及其密切接触者;否认14天内去过以下场所:水产、肉类批发市场,农贸市场,集市,大型超市,夜市;否认14天内与以下场所工作人员密切接触:水产、肉类批发市场,农贸市场,集市,大型超市;否认14天内周围(如家庭、办公室)有2例以上聚集性发病;否认14天内接触过有发热或呼吸道症状的人员;否认14天内自身有发热或呼吸道症状;否认14天内接触过纳入隔离观察的人员及其他可能与新冠肺炎关联的情形;陪同家属无以上情况。",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "control",
+ "control": {
+ "conceptId": "6",
+ "type": "text",
+ "value": [],
+ "placeholder": "内容",
+ "preText": "其他:",
+ "postText": "。"
+ }
+ },
+ {
+ "value": "\n",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "体格检查:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "\nT:39.5℃",
+ "size": 16
+ },
+ {
+ "value": "∆",
+ "type": "subscript",
+ "color": "#FF0000"
+ },
+ {
+ "value": ",P:80bpm,R:20次/分,BP:120/80mmHg;\n",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "辅助检查:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "\n2020年6月10日,普放:",
+ "size": 16
+ },
+ {
+ "value": "血细胞比容",
+ "highlight": "#F2F27F",
+ "groupIds": [
+ "1"
+ ]
+ },
+ {
+ "value": "36.50%(偏低)40~50;单核细胞绝对值0.75*10",
+ "size": 16
+ },
+ {
+ "value": "9",
+ "type": "superscript"
+ },
+ {
+ "value": "/L(偏高)参考值:0.1~0.6;\n",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "门诊诊断:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "",
+ "type": "list",
+ "valueList": [
+ {
+ "value": "\n高血压\n糖尿病\n病毒性感冒\n过敏性鼻炎\n过敏性鼻息肉"
+ }
+ ],
+ "listType": "ol"
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "处置治疗:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "",
+ "type": "list",
+ "valueList": [
+ {
+ "value": "\n超声引导下甲状腺细针穿刺术;\n乙型肝炎表面抗体测定;\n膜式病变细胞采集术、后颈皮下肤层;"
+ }
+ ],
+ "listType": "ol"
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "电子签名:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "【",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "image",
+ "width": 89,
+ "height": 32
+ },
+ {
+ "value": "】\n",
+ "size": 16
+ },
+ {
+ "value": "",
+ "type": "title",
+ "valueList": [
+ {
+ "value": "其他记录:",
+ "size": 18,
+ "bold": true
+ }
+ ],
+ "level": "first"
+ },
+ {
+ "value": "",
+ "type": "table",
+ "trList": [
+ {
+ "height": 42,
+ "tdList": [
+ {
+ "colspan": 1,
+ "rowspan": 2,
+ "value": [
+ {
+ "value": "1.",
+ "size": 16
+ }
+ ]
+ },
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "2.",
+ "size": 16
+ }
+ ]
+ },
+ {
+ "colspan": 2,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "3.",
+ "size": 16
+ }
+ ]
+ }
+ ],
+ "minHeight": 42
+ },
+ {
+ "height": 42,
+ "tdList": [
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "4.",
+ "size": 16
+ }
+ ]
+ },
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "5.",
+ "size": 16
+ }
+ ]
+ },
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "6.",
+ "size": 16
+ }
+ ]
+ }
+ ],
+ "minHeight": 42
+ },
+ {
+ "height": 42,
+ "tdList": [
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "7.",
+ "size": 16
+ }
+ ]
+ },
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "8.",
+ "size": 16
+ }
+ ]
+ },
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "9.",
+ "size": 16
+ }
+ ]
+ },
+ {
+ "colspan": 1,
+ "rowspan": 1,
+ "value": [
+ {
+ "value": "10.",
+ "size": 16
+ }
+ ]
+ }
+ ],
+ "minHeight": 42
+ }
+ ],
+ "width": 520,
+ "height": 126,
+ "colgroup": [
+ {
+ "width": 180
+ },
+ {
+ "width": 80
+ },
+ {
+ "width": 130
+ },
+ {
+ "width": 130
+ }
+ ]
+ },
+ {
+ "value": "是否同意以上内容:"
+ },
+ {
+ "value": "",
+ "type": "control",
+ "control": {
+ "conceptId": "3",
+ "type": "checkbox",
+ "code": "98175",
+ "value": [
+ {
+ "value": "同意否定"
+ }
+ ],
+ "valueSets": [
+ {
+ "value": "同意",
+ "code": "98175"
+ },
+ {
+ "value": "否定",
+ "code": "98176"
+ }
+ ]
+ }
+ },
+ {
+ "value": "\n医学公式:"
+ },
+ {
+ "value": "{E_k} = hv - {W_0}",
+ "type": "latex",
+ "width": 102,
+ "height": 25
+ },
+ {
+ "value": "\n签署日期:"
+ },
+ {
+ "value": "",
+ "type": "control",
+ "control": {
+ "conceptId": "5",
+ "type": "date",
+ "value": [
+ {
+ "value": "2022-08-10 17:30:01",
+ "type": "text"
+ }
+ ],
+ "placeholder": "签署日期"
+ }
+ },
+ {
+ "value": "\n患者签名:"
+ },
+ {
+ "value": "",
+ "type": "control",
+ "control": {
+ "conceptId": "4",
+ "type": "text",
+ "value": [],
+ "placeholder": "",
+ "prefix": "",
+ "postfix": "",
+ "minWidth": 160,
+ "underline": true
+ }
+ },
+ {
+ "value": "\n"
+ },
+ {
+ "value": "",
+ "type": "tab"
+ },
+ {
+ "value": "EOF",
+ "size": 16
+ }
+ ],
+ "footer": []
+}
\ No newline at end of file
diff --git a/src/main.ts b/src/main.ts
index 923dfa1..5a1c9fe 100644
--- a/src/main.ts
+++ b/src/main.ts
@@ -66,6 +66,34 @@ window.onload = function () {
// cypress使用
Reflect.set(window, 'editor', instance)
+ // 通过 URL 参数 filePath 自动打开同源文件(iframe 场景)
+ const params = new URLSearchParams(window.location.search)
+ const filePath = params.get('filePath')
+ if (filePath) {
+ const url = new URL(filePath, window.location.href).toString()
+ fetch(url)
+ .then(res => res.text())
+ .then(text => {
+ try {
+ let editorData
+ try {
+ editorData = JSON.parse(text)
+ } catch {
+ editorData = { main: [{ value: text }] }
+ }
+ instance.command.executeSetValue(editorData)
+ console.log('[iframe] 根据 filePath 加载完成:', url)
+ } catch (err) {
+ console.error('[iframe] 加载失败:', err)
+ alert('通过参数加载文件失败,请检查格式与同源权限')
+ }
+ })
+ .catch(err => {
+ console.error('[iframe] 获取文件失败:', err)
+ alert('无法获取 filePath 指定的文件')
+ })
+ }
+
// 菜单弹窗销毁
window.addEventListener(
'click',