qlfy-postmate 1.2.9 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/index.mjs +96 -50
- package/lib/index.mjs.gz +0 -0
- package/lib/index.mjs.map +1 -1
- package/lib/index.umd.js +1 -1
- package/lib/index.umd.js.gz +0 -0
- package/lib/index.umd.js.map +1 -1
- package/lib/postMeta/ChildPostmate.d.ts +5 -4
- package/lib/postMeta/RouteMatching.d.ts +5 -0
- package/lib/postMeta/tools.d.ts +1 -0
- package/package.json +3 -2
- package/lib/postMeta_back/ChildPostmate.d.ts +0 -34
- package/lib/postMeta_back/ParentPostmate.d.ts +0 -61
- package/lib/postMeta_back/index.d.ts +0 -3
package/lib/index.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
const u = "application/x-postmate-v1+json";
|
|
2
|
-
let
|
|
3
|
-
const
|
|
2
|
+
let w = 0;
|
|
3
|
+
const U = {
|
|
4
4
|
handshake: 1,
|
|
5
5
|
"handshake-reply": 1,
|
|
6
6
|
call: 1,
|
|
@@ -8,20 +8,20 @@ const R = {
|
|
|
8
8
|
reply: 1,
|
|
9
9
|
request: 1
|
|
10
10
|
};
|
|
11
|
-
function
|
|
12
|
-
return (typeof e != "string" || i.origin === e) && !!i.data && (typeof i.data != "object" || "postmate" in i.data) && i.data.type === u && !!
|
|
11
|
+
function f(i, e) {
|
|
12
|
+
return (typeof e != "string" || i.origin === e) && !!i.data && (typeof i.data != "object" || "postmate" in i.data) && i.data.type === u && !!U[i.data.postmate];
|
|
13
13
|
}
|
|
14
|
-
class
|
|
14
|
+
class E {
|
|
15
15
|
constructor(e) {
|
|
16
16
|
this.parent = e.parent, this.frame = e.frame, this.child = e.child, this.childOrigin = e.childOrigin, this.events = {}, this.listener = (t) => {
|
|
17
|
-
if (!
|
|
17
|
+
if (!f(t, this.childOrigin)) return;
|
|
18
18
|
const { value: s = {} } = t.data, { name: r, data: a } = s;
|
|
19
19
|
t.data.postmate === "emit" && r in this.events && this.events[r].call(this, a);
|
|
20
20
|
}, this.parent.addEventListener("message", this.listener, !1);
|
|
21
21
|
}
|
|
22
22
|
get(e) {
|
|
23
23
|
return new l.Promise((t) => {
|
|
24
|
-
const s = ++
|
|
24
|
+
const s = ++w, r = (a) => {
|
|
25
25
|
a.data.uid === s && a.data.postmate === "reply" && (this.parent.removeEventListener("message", r, !1), t(a.data.value));
|
|
26
26
|
};
|
|
27
27
|
this.parent.addEventListener("message", r, !1), this.child.postMessage(
|
|
@@ -53,10 +53,10 @@ class w {
|
|
|
53
53
|
window.removeEventListener("message", this.listener, !1), this.frame.parentNode.removeChild(this.frame);
|
|
54
54
|
}
|
|
55
55
|
}
|
|
56
|
-
class
|
|
56
|
+
class _ {
|
|
57
57
|
constructor(e) {
|
|
58
58
|
this.model = e.model, this.parent = e.parent, this.parentOrigin = e.parentOrigin, this.child = e.child, this.child.addEventListener("message", (t) => {
|
|
59
|
-
if (!
|
|
59
|
+
if (!f(t, this.parentOrigin)) return;
|
|
60
60
|
const { postmate: s, property: r, uid: a, data: o } = t.data, n = this.model[r];
|
|
61
61
|
if (s !== "call") {
|
|
62
62
|
const h = typeof n == "function" ? n() : n;
|
|
@@ -100,8 +100,8 @@ class l {
|
|
|
100
100
|
let s = 0, r;
|
|
101
101
|
return new l.Promise((a, o) => {
|
|
102
102
|
const n = (d) => {
|
|
103
|
-
if (!
|
|
104
|
-
d.data.postmate === "handshake-reply" ? (clearInterval(r), this.parent.removeEventListener("message", n, !1), this.childOrigin = d.origin, a(new
|
|
103
|
+
if (!f(d, t)) return !1;
|
|
104
|
+
d.data.postmate === "handshake-reply" ? (clearInterval(r), this.parent.removeEventListener("message", n, !1), this.childOrigin = d.origin, a(new E(this))) : o("Failed handshake");
|
|
105
105
|
};
|
|
106
106
|
this.parent.addEventListener("message", n, !1);
|
|
107
107
|
const h = () => {
|
|
@@ -120,7 +120,7 @@ class l {
|
|
|
120
120
|
});
|
|
121
121
|
}
|
|
122
122
|
}
|
|
123
|
-
class
|
|
123
|
+
class O {
|
|
124
124
|
constructor(e) {
|
|
125
125
|
return this.child = window, this.model = e, this.parent = window.parent, this.sendHandshakeReply();
|
|
126
126
|
}
|
|
@@ -139,7 +139,7 @@ class E {
|
|
|
139
139
|
const r = s.data.model;
|
|
140
140
|
r && Object.keys(r).forEach((a) => {
|
|
141
141
|
this.model[a] = r[a];
|
|
142
|
-
}), e(new
|
|
142
|
+
}), e(new _(this));
|
|
143
143
|
}
|
|
144
144
|
}, !1);
|
|
145
145
|
});
|
|
@@ -153,19 +153,54 @@ l.Promise = (() => {
|
|
|
153
153
|
return Promise;
|
|
154
154
|
}
|
|
155
155
|
})();
|
|
156
|
-
l.Model =
|
|
157
|
-
|
|
156
|
+
l.Model = O;
|
|
157
|
+
const v = (i) => {
|
|
158
|
+
if (!i || i === "/") return "";
|
|
159
|
+
const e = i.replace(/\/$/, "");
|
|
160
|
+
return e.startsWith("/") ? e : `/${e}`;
|
|
161
|
+
}, I = (i, e = "") => {
|
|
162
|
+
if (!i) return null;
|
|
163
|
+
const t = v(e);
|
|
164
|
+
let s = "";
|
|
165
|
+
try {
|
|
166
|
+
s = new URL(i).pathname;
|
|
167
|
+
} catch {
|
|
168
|
+
s = i.split(/[?#]/)[0];
|
|
169
|
+
}
|
|
170
|
+
const r = s.replace(/\/+/g, "/").replace(/\/$/, "") || "/";
|
|
171
|
+
if (t && !r.startsWith(t))
|
|
172
|
+
return null;
|
|
173
|
+
let a = t ? r.slice(t.length) : r;
|
|
174
|
+
return a = a.replace(/\/+/g, "/"), a = a.startsWith("/") ? a : `/${a}`, a === "" ? "/" : a;
|
|
175
|
+
}, S = (i) => {
|
|
176
|
+
if (!i) return /^$/iu;
|
|
177
|
+
let t = (i.replace(/\/+/g, "/").replace(/\/$/, "") || "/").replace(/([.?+^$[\](){}|-])/g, "\\$1");
|
|
178
|
+
return t = t.replace(/:pathMatch\\\(\.\*\\\)\*/g, ".+").replace(/:([a-zA-Z0-9_]+)\\\(([^)]+)\\\)/g, (s, r, a) => a.replace(/\\\\/g, "\\")).replace(/:([a-zA-Z0-9_]+)\?/g, "[^/]*").replace(/:([a-zA-Z0-9_]+)/g, "[^/]+"), t = t.replace(/\/+/g, "\\/"), new RegExp(`^${t}$`, "iu");
|
|
179
|
+
}, P = (i, e, t = "") => {
|
|
180
|
+
const s = e.replace(/\/+/g, "/").replace(/\/$/, "") || "/";
|
|
181
|
+
for (const r of i) {
|
|
182
|
+
const a = t.replace(/\/+/g, "/").replace(/\/$/, ""), o = r.path.replace(/\/+/g, "/").replace(/^\//, ""), n = a ? `${a}/${o}`.replace(/\/+/g, "/") : r.path.replace(/\/+/g, "/");
|
|
183
|
+
if (S(n).test(s) || r.children && r.children.length && P(r.children, s, n))
|
|
184
|
+
return !0;
|
|
185
|
+
}
|
|
186
|
+
return !1;
|
|
187
|
+
}, p = (i, e, t = "") => {
|
|
188
|
+
if (!i || !i.length || !e) return !1;
|
|
189
|
+
const s = I(e, t);
|
|
190
|
+
return s ? P(i, s) : !1;
|
|
191
|
+
};
|
|
192
|
+
function R(i, e) {
|
|
158
193
|
for (const t of i)
|
|
159
|
-
if (t.path === e || t.children && Array.isArray(t.children) && t.children.length > 0 &&
|
|
194
|
+
if (t.path === e || t.children && Array.isArray(t.children) && t.children.length > 0 && R(t.children, e))
|
|
160
195
|
return !0;
|
|
161
196
|
return !1;
|
|
162
197
|
}
|
|
163
|
-
function
|
|
198
|
+
function C(i, e) {
|
|
164
199
|
e.includes("?") && (e = e.split("?")[0]);
|
|
165
|
-
const t =
|
|
166
|
-
return !t || t.length === 0 ? !1 :
|
|
200
|
+
const t = m(i);
|
|
201
|
+
return !t || t.length === 0 ? !1 : R(t, e);
|
|
167
202
|
}
|
|
168
|
-
function
|
|
203
|
+
function y(i) {
|
|
169
204
|
const e = {
|
|
170
205
|
path: i.path,
|
|
171
206
|
name: i.name,
|
|
@@ -174,15 +209,15 @@ function P(i) {
|
|
|
174
209
|
redirect: i.redirect,
|
|
175
210
|
// 剔除 component、beforeEnter 等可能包含函数/对象引用的字段
|
|
176
211
|
// 如果需要children,递归净化
|
|
177
|
-
children: i.children ? i.children.map((t) =>
|
|
212
|
+
children: i.children ? i.children.map((t) => y(t)) : []
|
|
178
213
|
};
|
|
179
214
|
return e.meta = JSON.parse(JSON.stringify(e.meta)), e;
|
|
180
215
|
}
|
|
181
|
-
function
|
|
216
|
+
function m(i) {
|
|
182
217
|
let e = [];
|
|
183
|
-
return typeof i.getRoutes == "function" ? e = i.getRoutes() : i.options && Array.isArray(i.options.routes) && (e = i.options.routes), e.map((t) =>
|
|
218
|
+
return typeof i.getRoutes == "function" ? e = i.getRoutes() : i.options && Array.isArray(i.options.routes) && (e = i.options.routes), e.map((t) => y(t)) || [];
|
|
184
219
|
}
|
|
185
|
-
function
|
|
220
|
+
function $(i, e) {
|
|
186
221
|
try {
|
|
187
222
|
const t = new URL(i), s = new URL(e), r = t.protocol.toLowerCase() === s.protocol.toLowerCase(), a = t.hostname === s.hostname, o = t.port === s.port;
|
|
188
223
|
return r && a && o;
|
|
@@ -201,9 +236,19 @@ const g = () => {
|
|
|
201
236
|
return t;
|
|
202
237
|
};
|
|
203
238
|
};
|
|
204
|
-
|
|
239
|
+
function M(i, e) {
|
|
240
|
+
let t = "", s = new URL(e);
|
|
241
|
+
e.split("?")[0];
|
|
242
|
+
let r = "";
|
|
243
|
+
if (s.hash && s.hash.indexOf("#/") > -1 ? r = s.hash.split("#")[1] : r = s.pathname, console.log(r), !p(i, r)) {
|
|
244
|
+
let a = r.split("/"), o = "/" + a.slice(2, a.length).join("/");
|
|
245
|
+
console.log(i, o), p(i, o) ? t = "/" + a[1] : console.error("仅支持vue-router一级base配置");
|
|
246
|
+
}
|
|
247
|
+
return t;
|
|
248
|
+
}
|
|
249
|
+
class k {
|
|
205
250
|
constructor(e, t, s) {
|
|
206
|
-
this.childPostmate = null, this.parentPostmate = null, this.isGetData = !1, this.getDataCllBack = null, this.stateOver = !1, this.router = null, this.
|
|
251
|
+
this.childPostmate = null, this.parentPostmate = null, this.isGetData = !1, this.getDataCllBack = null, this.stateOver = !1, this.router = null, this.customRouteChange = void 0, this.router = t, this.customRouteChange = s, window.top !== window.self ? (this.init(e), setTimeout(() => {
|
|
207
252
|
this.stateOver || e.error({ status: 500, data: null, message: "未在一体化平台中运行" });
|
|
208
253
|
}, 500)) : e.error({ status: 500, data: null, message: "未在一体化平台中运行" });
|
|
209
254
|
}
|
|
@@ -225,20 +270,20 @@ class C {
|
|
|
225
270
|
// 提供当前系统的路由
|
|
226
271
|
getRoutes: () => {
|
|
227
272
|
if (t.router) {
|
|
228
|
-
let s =
|
|
273
|
+
let s = m(t.router);
|
|
229
274
|
t.parentPostmate.emit("pushRoutes", JSON.stringify(s, g()));
|
|
230
275
|
} else t.parentPostmate.emit("pushRoutes");
|
|
231
276
|
},
|
|
232
277
|
// 检查路由是否存在
|
|
233
278
|
isRouteExists(s) {
|
|
234
|
-
t.router ? t.parentPostmate.emit("routeExists",
|
|
279
|
+
t.router ? t.parentPostmate.emit("routeExists", C(t.router, s)) : t.parentPostmate.emit("routeExists", !1);
|
|
235
280
|
},
|
|
236
281
|
// 处理路由更新
|
|
237
282
|
routeUpdate(s) {
|
|
238
283
|
try {
|
|
239
284
|
const r = JSON.parse(s);
|
|
240
|
-
if (t.
|
|
241
|
-
t.
|
|
285
|
+
if (t.customRouteChange) {
|
|
286
|
+
t.customRouteChange(r), t.parentPostmate.emit("route_update_result", !0), console.log("----------------- 【ChildPastMate】路由更新完成 -----------------");
|
|
242
287
|
return;
|
|
243
288
|
}
|
|
244
289
|
t.router ? (t.router.replace(r.fullPath), t.parentPostmate.emit("route_update_result", !0), console.log("----------------- 【ChildPastMate】路由更新完成 -----------------")) : (t.parentPostmate.emit("route_update_result", !1), console.warn("【ChildPastMate】未提供router实例,无法进行路由更新"));
|
|
@@ -253,7 +298,7 @@ class C {
|
|
|
253
298
|
data: {
|
|
254
299
|
ChildPostmate: s
|
|
255
300
|
}
|
|
256
|
-
}), t.parentPostmate.emit("route_update_support", !!t.router), t.router && t.parentPostmate.emit("pushRoutes", JSON.stringify(
|
|
301
|
+
}), t.parentPostmate.emit("route_update_support", !!t.router), t.router && t.parentPostmate.emit("pushRoutes", JSON.stringify(m(t.router), g()));
|
|
257
302
|
}).catch((s) => {
|
|
258
303
|
this.stateOver = !0, e.error({ status: 500, data: null, message: s });
|
|
259
304
|
});
|
|
@@ -273,10 +318,10 @@ class C {
|
|
|
273
318
|
/**
|
|
274
319
|
* 设置路由实例和路由更新回调
|
|
275
320
|
* @param router Vue Router实例
|
|
276
|
-
* @param
|
|
321
|
+
* @param customRouteChange 自定义路由更新回调函数
|
|
277
322
|
*/
|
|
278
323
|
setRouter(e, t) {
|
|
279
|
-
this.router = e, t && (this.
|
|
324
|
+
this.router = e, t && (this.customRouteChange = t);
|
|
280
325
|
}
|
|
281
326
|
/**
|
|
282
327
|
* 向父页面发送其他请求
|
|
@@ -286,7 +331,7 @@ class C {
|
|
|
286
331
|
this.parentPostmate && this.parentPostmate.emit("otherRequest", e);
|
|
287
332
|
}
|
|
288
333
|
}
|
|
289
|
-
class
|
|
334
|
+
class B {
|
|
290
335
|
constructor(e, t, s = "", r) {
|
|
291
336
|
this.postmateParent = null, this.dataInfo = {
|
|
292
337
|
loginInfo: {},
|
|
@@ -294,7 +339,7 @@ class O {
|
|
|
294
339
|
isHideHeader: !0
|
|
295
340
|
}, this.iframeEle = null, this.currentUrl = "", this.currentIframe = null, this.loadFunction = null, this.handleOtherRequest = null, this.childSupportsRouteUpdate = !0, this.childRoutes = [], this.eventBus = {
|
|
296
341
|
getRoutes: null,
|
|
297
|
-
|
|
342
|
+
route_update_result: null
|
|
298
343
|
}, this.dataInfo = e || this.dataInfo, this.iframeEle = t, this.setIframeUrl(s), r && (this.handleOtherRequest = r);
|
|
299
344
|
}
|
|
300
345
|
/** 解析URL */
|
|
@@ -386,7 +431,7 @@ class O {
|
|
|
386
431
|
this.currentUrl = e, this.iframeEle ? this.init() : console.error("【ParentPostmate】无 iframe 容器,无法初始化");
|
|
387
432
|
return;
|
|
388
433
|
}
|
|
389
|
-
if (!this.childSupportsRouteUpdate || !((r = this.childRoutes) != null && r.length) ||
|
|
434
|
+
if (!this.childSupportsRouteUpdate || !((r = this.childRoutes) != null && r.length) || !$(this.currentUrl, e)) {
|
|
390
435
|
this.currentUrl = e, this.init();
|
|
391
436
|
return;
|
|
392
437
|
}
|
|
@@ -399,21 +444,22 @@ class O {
|
|
|
399
444
|
}
|
|
400
445
|
// 处理相似地址
|
|
401
446
|
handleSimilarUrl(e, t) {
|
|
402
|
-
|
|
447
|
+
let s = e.split("?").length > 1, r = "";
|
|
448
|
+
if (s && (r = "?" + e.split("?")[1]), t && p(this.childRoutes, t)) {
|
|
403
449
|
this.sendRouteUpdate({
|
|
404
|
-
fullPath: t
|
|
405
|
-
});
|
|
450
|
+
fullPath: t + r
|
|
451
|
+
}), this.currentUrl = e;
|
|
406
452
|
return;
|
|
407
453
|
}
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
454
|
+
const a = M(this.childRoutes, this.currentUrl);
|
|
455
|
+
let o = new URL(e), n = "";
|
|
456
|
+
if (o.hash && o.hash.indexOf("#/") > -1 ? n = o.hash.split("#")[1] : n = o.pathname + r, console.log(this.childRoutes, n.replace(a, "")), this.currentUrl.split(a)[0] === e.split(a)[0] && p(this.childRoutes, n.replace(a, ""))) {
|
|
457
|
+
this.sendRouteUpdate({
|
|
458
|
+
fullPath: n.replace(a, "")
|
|
459
|
+
}), console.log("推送地址:", e), console.log("推送路由:", n.replace(a, "")), console.log("当前地址:", this.currentUrl), this.currentUrl = e;
|
|
460
|
+
return;
|
|
461
|
+
}
|
|
462
|
+
this.currentUrl = e, this.init();
|
|
417
463
|
}
|
|
418
464
|
/** 向子页面发送路由更新消息 */
|
|
419
465
|
sendRouteUpdate(e) {
|
|
@@ -440,7 +486,7 @@ class O {
|
|
|
440
486
|
}
|
|
441
487
|
}
|
|
442
488
|
export {
|
|
443
|
-
|
|
444
|
-
|
|
489
|
+
k as ChildPostmate,
|
|
490
|
+
B as ParentPostmate
|
|
445
491
|
};
|
|
446
492
|
//# sourceMappingURL=index.mjs.map
|
package/lib/index.mjs.gz
CHANGED
|
Binary file
|
package/lib/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../packages/postMeta/postMeta.js","../packages/postMeta/tools.ts","../packages/postMeta/ChildPostmate.ts","../packages/postMeta/ParentPostmate.ts"],"sourcesContent":["const MESSAGE_TYPE = \"application/x-postmate-v1+json\";\nlet uid = 0;\n\nconst allowedPostmateTypes = {\n handshake: 1,\n \"handshake-reply\": 1,\n call: 1,\n emit: 1,\n reply: 1,\n request: 1,\n};\n\n// 校验消息是否来自合法的来源\nfunction isValidMessage(event, allowedOrigin) {\n return (\n (typeof allowedOrigin !== \"string\" || event.origin === allowedOrigin) &&\n !!event.data &&\n (typeof event.data !== \"object\" || \"postmate\" in event.data) &&\n event.data.type === MESSAGE_TYPE &&\n !!allowedPostmateTypes[event.data.postmate]\n );\n}\n\n// ----------------- ParentAPI -----------------\nclass ParentAPI {\n constructor(config) {\n this.parent = config.parent;\n this.frame = config.frame;\n this.child = config.child;\n this.childOrigin = config.childOrigin;\n this.events = {};\n\n this.listener = (event) => {\n if (!isValidMessage(event, this.childOrigin)) return;\n const { value = {} } = event.data;\n const { name, data } = value;\n if (event.data.postmate === \"emit\" && name in this.events) {\n this.events[name].call(this, data);\n }\n };\n\n this.parent.addEventListener(\"message\", this.listener, false);\n }\n\n get(property) {\n return new Postmate.Promise((resolve) => {\n const id = ++uid;\n const handler = (event) => {\n if (event.data.uid === id && event.data.postmate === \"reply\") {\n this.parent.removeEventListener(\"message\", handler, false);\n resolve(event.data.value);\n }\n };\n this.parent.addEventListener(\"message\", handler, false);\n this.child.postMessage(\n {\n postmate: \"request\",\n type: MESSAGE_TYPE,\n property,\n uid: id,\n },\n this.childOrigin\n );\n });\n }\n\n call(method, data) {\n this.child.postMessage(\n {\n postmate: \"call\",\n type: MESSAGE_TYPE,\n property: method,\n data,\n },\n this.childOrigin\n );\n }\n\n on(event, callback) {\n this.events[event] = callback;\n }\n\n destroy() {\n window.removeEventListener(\"message\", this.listener, false);\n this.frame.parentNode.removeChild(this.frame);\n }\n}\n\n// ----------------- ChildAPI -----------------\nclass ChildAPI {\n constructor(config) {\n this.model = config.model;\n this.parent = config.parent;\n this.parentOrigin = config.parentOrigin;\n this.child = config.child;\n\n this.child.addEventListener(\"message\", (event) => {\n if (!isValidMessage(event, this.parentOrigin)) return;\n\n const { postmate, property, uid, data } = event.data;\n const value = this.model[property];\n\n if (postmate !== \"call\") {\n const result = typeof value === \"function\" ? value() : value;\n Postmate.Promise.resolve(result).then((res) => {\n event.source.postMessage(\n {\n property,\n postmate: \"reply\",\n type: MESSAGE_TYPE,\n uid,\n value: res,\n },\n event.origin\n );\n });\n } else if (property in this.model && typeof value === \"function\") {\n value(data);\n }\n });\n }\n\n emit(eventName, data) {\n this.parent.postMessage(\n {\n postmate: \"emit\",\n type: MESSAGE_TYPE,\n value: { name: eventName, data },\n },\n this.parentOrigin\n );\n }\n}\n\n// ----------------- Postmate -----------------\nclass Postmate {\n constructor({ container = document.body, model, url, name, classListArray = [] }) {\n this.parent = window;\n this.frame = document.createElement(\"iframe\");\n this.frame.name = name || \"\";\n this.frame.classList.add(...classListArray);\n container.appendChild(this.frame);\n\n this.child = this.frame.contentWindow;\n this.model = model || {};\n\n return this.sendHandshake(url);\n }\n\n sendHandshake(url) {\n const origin = (() => {\n const link = document.createElement(\"a\");\n link.href = url;\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n const host = link.host.length ? (link.port === \"80\" || link.port === \"443\" ? link.hostname : link.host) : window.location.host;\n return link.origin || `${protocol}//${host}`;\n })();\n\n let attemptCount = 0;\n let interval;\n\n return new Postmate.Promise((resolve, reject) => {\n const listener = (event) => {\n if (!isValidMessage(event, origin)) return false;\n if (event.data.postmate === \"handshake-reply\") {\n clearInterval(interval);\n this.parent.removeEventListener(\"message\", listener, false);\n this.childOrigin = event.origin;\n resolve(new ParentAPI(this));\n } else {\n reject(\"Failed handshake\");\n }\n };\n\n this.parent.addEventListener(\"message\", listener, false);\n\n const send = () => {\n attemptCount++;\n this.child.postMessage(\n {\n postmate: \"handshake\",\n type: MESSAGE_TYPE,\n model: this.model,\n },\n origin\n );\n if (attemptCount === 5) clearInterval(interval);\n };\n\n const init = () => {\n send();\n interval = setInterval(send, 500);\n };\n\n this.frame.onload = init;\n this.frame.attachEvent && this.frame.attachEvent(\"onload\", init);\n this.frame.src = url;\n });\n }\n}\n\n// ----------------- Model -----------------\nclass Model {\n constructor(model) {\n this.child = window;\n this.model = model;\n this.parent = window.parent;\n\n return this.sendHandshakeReply();\n }\n\n sendHandshakeReply() {\n return new Postmate.Promise((resolve, reject) => {\n this.child.addEventListener(\"message\", (event) => {\n if (event.data.postmate) {\n if (event.data.postmate !== \"handshake\") return reject(\"Handshake Reply Failed\");\n\n this.child.removeEventListener(\"message\", this, false);\n event.source.postMessage(\n {\n postmate: \"handshake-reply\",\n type: MESSAGE_TYPE,\n },\n event.origin\n );\n\n this.parentOrigin = event.origin;\n const parentModel = event.data.model;\n if (parentModel) {\n Object.keys(parentModel).forEach((key) => {\n this.model[key] = parentModel[key];\n });\n }\n resolve(new ChildAPI(this));\n }\n }, false);\n });\n }\n}\n\n// Attach defaults\nPostmate.debug = false;\nPostmate.Promise = (() => {\n try {\n return typeof window !== \"undefined\" ? window.Promise : Promise;\n } catch {\n return Promise;\n }\n})();\nPostmate.Model = Model;\n\nexport default Postmate;\nexport { Model };\n","/**\n * 检查路径是否存在于路由配置中(递归检查所有层级)\n * @param routes 路由配置数组\n * @param path 需要检查的路径\n * @returns 是否存在\n */\nexport function checkPathInRoutes(routes: any[], path: string): boolean {\n\tfor (const route of routes) {\n\t\t// 检查当前路由\n\t\tif (route.path === path) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// 递归检查子路由\n\t\tif (route.children && Array.isArray(route.children) && route.children.length > 0) {\n\t\t\tif (checkPathInRoutes(route.children, path)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n}\n\n/**\n * 判断路径是否存在于vue-router对象中(兼容Vue2和Vue3)\n * @param router vue-router实例\n * @param path 需要检查的页面路径\n * @returns 路径是否存在\n */\nexport function isRouteExists(router: any, path: string): boolean {\n\t// 移除路径中的查询参数\n\tif (path.includes('?')) {\n\t\tpath = path.split('?')[0];\n\t}\n\tconst routes = getRouterPaths(router);\n\tif (!routes || routes.length === 0) return false;\n\treturn checkPathInRoutes(routes, path);\n}\n\n// 净化单个路由配置,只保留安全字段\nfunction purifyRoute(route) {\n\t// 只提取需要的基础字段,根据你的需求调整\n\tconst safeFields = {\n\t\tpath: route.path,\n\t\tname: route.name,\n\t\tmeta: route.meta || {}, // 确保meta是普通对象\n\t\tredirect: route.redirect,\n\t\t// 剔除 component、beforeEnter 等可能包含函数/对象引用的字段\n\t\t// 如果需要children,递归净化\n\t\tchildren: route.children ? route.children.map((child) => purifyRoute(child)) : [],\n\t};\n\n\t// 进一步净化meta(如果meta中可能有复杂对象)\n\tsafeFields.meta = JSON.parse(JSON.stringify(safeFields.meta));\n\n\treturn safeFields;\n}\n\n/**\n * 获取路由路径\n *\n */\nexport function getRouterPaths(router: any): any[] {\n\tlet routes: any[] = [];\n\t// 区分Vue Router 3.x (Vue2) 和 4.x (Vue3)\n\tif (typeof router.getRoutes === 'function') {\n\t\t// Vue Router 4.x (Vue3)\n\t\troutes = router.getRoutes();\n\t} else if (router.options && Array.isArray(router.options.routes)) {\n\t\t// Vue Router 3.x (Vue2)\n\t\troutes = router.options.routes;\n\t}\n\treturn routes.map((route) => purifyRoute(route)) || [];\n}\n\n/**\n * 比较两个URL的协议、IP(或域名)和端口是否完全相同\n * @param url1 第一个URL字符串\n * @param url2 第二个URL字符串\n * @returns 如果协议、IP(或域名)和端口都相同则返回true,否则返回false;解析失败时返回false\n */\nexport function areUrlsSameProtocolIpPort(url1: string, url2: string): boolean {\n\ttry {\n\t\t// 解析两个URL\n\t\tconst parsedUrl1 = new URL(url1);\n\t\tconst parsedUrl2 = new URL(url2);\n\n\t\t// 比较协议(不区分大小写,但通常URL协议是小写的)\n\t\tconst sameProtocol = parsedUrl1.protocol.toLowerCase() === parsedUrl2.protocol.toLowerCase();\n\n\t\t// 比较主机(IP或域名)\n\t\tconst sameHost = parsedUrl1.hostname === parsedUrl2.hostname;\n\n\t\t// 比较端口(如果未指定端口,会使用协议默认端口)\n\t\tconst samePort = parsedUrl1.port === parsedUrl2.port;\n\n\t\t// 只有所有部分都相同时才返回true\n\t\treturn sameProtocol && sameHost && samePort;\n\t} catch (error) {\n\t\t// 如果URL解析失败,返回false\n\t\tconsole.error('URL解析错误:', error);\n\t\treturn false;\n\t}\n}\n\nexport const getCircularReplacer = () => {\n\tconst seen = new WeakSet();\n\treturn (key, value) => {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tif (seen.has(value)) {\n\t\t\t\t// 遇到循环引用时,返回一个标识或忽略\n\t\t\t\treturn '[Circular Reference]';\n\t\t\t}\n\t\t\tseen.add(value);\n\t\t}\n\t\treturn value;\n\t};\n};\n","import Postmate from './postMeta';\nimport { getCircularReplacer, getRouterPaths, isRouteExists } from './tools';\n\ninterface EventObj {\n\terror: (error: any) => void;\n\tsuccess: (success: any) => void;\n\treceive: (receive: any) => void;\n}\n\n// 路由更新接口\ninterface RouteUpdateInfo {\n\tfullPath: string;\n}\n\nexport default class ChildPostmate {\n\tchildPostmate: any = null;\n\tparentPostmate: any = null;\n\n\tisGetData: boolean = false;\n\tgetDataCllBack: Function | null = null;\n\tstateOver: boolean = false;\n\n\t// Vue Router实例\n\trouter: any = null;\n\t// 路由更新回调函数\n\trouteUpdateCallback: ((routeInfo: RouteUpdateInfo) => void) | undefined = undefined;\n\n\tconstructor(eventObj: EventObj, router: any, routeUpdateCallback?: (routeInfo: RouteUpdateInfo) => void) {\n\t\t// 保存router实例\n\t\tthis.router = router;\n\t\t// 保存路由更新回调函数\n\t\tthis.routeUpdateCallback = routeUpdateCallback;\n\n\t\tif (window.top !== window.self) {\n\t\t\tthis.init(eventObj);\n\t\t\tsetTimeout(() => {\n\t\t\t\tif (this.stateOver) return;\n\t\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t\t}, 500);\n\t\t} else {\n\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t}\n\t}\n\n\tinit(eventObj: EventObj) {\n\t\tconst that = this;\n\t\t// 创建 Postmate Model(作为子)\n\t\tthis.childPostmate = new Postmate.Model({\n\t\t\t// 定义子页面可以暴露给父页面的方法\n\t\t\tbaseData(data: any) {\n\t\t\t\tdata = JSON.parse(data);\n\t\t\t\tif (that.isGetData) {\n\t\t\t\t\tthat.getDataCllBack &&\n\t\t\t\t\t\tthat.getDataCllBack({\n\t\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\t\tdata: data,\n\t\t\t\t\t\t});\n\t\t\t\t} else\n\t\t\t\t\teventObj.receive({\n\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\tdata: data,\n\t\t\t\t\t});\n\t\t\t\tthat.isGetData = false;\n\t\t\t},\n\n\t\t\t// 提供当前系统的路由\n\t\t\tgetRoutes: () => {\n\t\t\t\t// 有路由\n\t\t\t\tif (that.router) {\n\t\t\t\t\tlet arr = getRouterPaths(that.router);\n\t\t\t\t\tthat.parentPostmate.emit('pushRoutes', JSON.stringify(arr, getCircularReplacer()));\n\t\t\t\t}\n\t\t\t\t// 无路由\n\t\t\t\telse that.parentPostmate.emit('pushRoutes');\n\t\t\t},\n\n\t\t\t// 检查路由是否存在\n\t\t\tisRouteExists(routePath: string) {\n\t\t\t\tif (that.router) that.parentPostmate.emit('routeExists', isRouteExists(that.router, routePath));\n\t\t\t\telse that.parentPostmate.emit('routeExists', false);\n\t\t\t},\n\n\t\t\t// 处理路由更新\n\t\t\trouteUpdate(routeInfoStr: string) {\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\ttry {\n\t\t\t\t\tconst routeInfo: RouteUpdateInfo = JSON.parse(routeInfoStr);\n\n\t\t\t\t\t// 如果提供了自定义的路由更新回调函数,则调用它\n\t\t\t\t\tif (that.routeUpdateCallback) {\n\t\t\t\t\t\tthat.routeUpdateCallback(routeInfo);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t// 如果提供了router实例,则使用router进行路由更新\n\t\t\t\t\tif (that.router) {\n\t\t\t\t\t\tthat.router.replace(routeInfo.fullPath);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t\t\tconsole.warn('【ChildPastMate】未提供router实例,无法进行路由更新');\n\t\t\t\t\t}\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsole.error('【ChildPastMate】路由更新失败:', error);\n\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t}\n\t\t\t},\n\t\t})\n\t\t\t.then((parent: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\tthat.parentPostmate = parent;\n\t\t\t\tthat.getData();\n\t\t\t\t// 与父页面链接建立成功\n\t\t\t\teventObj.success({\n\t\t\t\t\tstatus: 200,\n\t\t\t\t\tmessage: 'success',\n\t\t\t\t\tdata: {\n\t\t\t\t\t\tChildPostmate: parent,\n\t\t\t\t\t},\n\t\t\t\t});\n\t\t\t\t// 告诉父系统支持路由更新\n\t\t\t\tthat.parentPostmate.emit('route_update_support', that.router ? true : false);\n\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\tthat.router && that.parentPostmate.emit('pushRoutes', JSON.stringify(getRouterPaths(that.router), getCircularReplacer()));\n\t\t\t})\n\t\t\t.catch((err: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\teventObj.error({ status: 500, data: null, message: err });\n\t\t\t});\n\t}\n\n\t// 获取数据\n\tgetData(callback?: any) {\n\t\tif (!this.parentPostmate) {\n\t\t\tcallback({\n\t\t\t\tstatus: 500,\n\t\t\t\tmessage: '父页面未连接',\n\t\t\t\tdata: null,\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\n\t\tif (callback) {\n\t\t\tthis.isGetData = true;\n\t\t\tthis.getDataCllBack = callback;\n\t\t} else {\n\t\t\tthis.isGetData = false;\n\t\t\tthis.getDataCllBack = null;\n\t\t}\n\t\t// 向父页面获取数据\n\t\tthis.parentPostmate.emit('requestBaseData');\n\t}\n\n\t/**\n\t * 设置路由实例和路由更新回调\n\t * @param router Vue Router实例\n\t * @param routeUpdateCallback 自定义路由更新回调函数\n\t */\n\tsetRouter(router: any, routeUpdateCallback?: (routeInfo: RouteUpdateInfo) => void) {\n\t\tthis.router = router;\n\t\tif (routeUpdateCallback) {\n\t\t\tthis.routeUpdateCallback = routeUpdateCallback;\n\t\t}\n\t}\n\n\t/**\n\t * 向父页面发送其他请求\n\t * @param params 请求参数\n\t */\n\tsendOtherRequest(params: any) {\n\t\tif (!this.parentPostmate) return;\n\t\tthis.parentPostmate.emit('otherRequest', params);\n\t}\n}\n","import Postmate from './postMeta';\nimport { areUrlsSameProtocolIpPort, checkPathInRoutes } from './tools';\n\ninterface DataInfo {\n loginInfo: { [x: string]: any };\n token: string;\n isHideHeader: boolean;\n}\n\n// URL解析结果接口\ninterface ParsedUrl {\n protocol: string;\n host: string;\n port: string;\n pathname: string;\n search: string;\n hash: string;\n origin: string;\n fullPath: string;\n}\n\nexport default class ParentPostmate {\n /** 连接到的子 postmate 实例 */\n postmateParent: any = null;\n /** 通讯数据 */\n dataInfo: DataInfo = {\n loginInfo: {},\n token: '',\n isHideHeader: true,\n };\n /** iframe Dom 容器 */\n iframeEle: any = null;\n /** 当前 iframe url */\n currentUrl: string = '';\n /** 存储当前的 iframe 元素 */\n currentIframe: any = null;\n /** iframe 加载完成执行函数 */\n loadFunction: (() => void) | null = null;\n /** 处理子类的其他请求方法 */\n handleOtherRequest: ((params: any) => void) | null = null;\n /** 子页面是否支持路由更新 */\n childSupportsRouteUpdate: boolean = true;\n /** 子系统的路由列表 */\n childRoutes: any[] = [];\n\n eventBus: any = {\n getRoutes: null,\n route_update_resultL: null,\n };\n\n constructor(\n dataInfo: DataInfo,\n iframeEle: HTMLElement | (() => HTMLElement),\n iframeUrl: string = '',\n handleOtherRequest?: (params: any) => void,\n ) {\n this.dataInfo = dataInfo || this.dataInfo;\n this.iframeEle = iframeEle;\n this.setIframeUrl(iframeUrl);\n handleOtherRequest && (this.handleOtherRequest = handleOtherRequest);\n }\n\n /** 解析URL */\n parseUrl(url: string): ParsedUrl {\n const link = document.createElement('a');\n link.href = url;\n\n // 获取协议\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n\n // 获取主机和端口\n const host = link.hostname;\n const port =\n link.port || (protocol === 'https:' ? '443' : protocol === 'http:' ? '80' : '');\n\n // 获取路径、查询参数和哈希\n const pathname = link.pathname.startsWith('/') ? link.pathname : `/${link.pathname}`;\n const search = link.search;\n const hash = link.hash.slice(2, link.hash.length);\n\n // 构建origin\n const origin = link.origin || `${protocol}//${host}${port ? `:${port}` : ''}`;\n\n // 构建完整路径(不包含origin)\n const fullPath = `${pathname}${hash}`;\n\n return {\n protocol,\n host,\n port,\n pathname,\n search,\n hash,\n origin,\n fullPath,\n };\n }\n\n /** 比较两个URL是否相同*/\n compareUrlBase(url1: string, url2: string): boolean {\n const url1End = url1.endsWith('/');\n const url2End = url2.endsWith('/');\n if ((url1End && url2End) || (!url1End && !url2End)) {\n return url1 === url2;\n } else {\n if (url1End) url2 += '/';\n if (url2End) url1 += '/';\n return url1 === url2;\n }\n }\n\n /** 比较两个URL的路径是否相同(不包含查询参数和哈希) */\n compareUrlPath(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.pathname === parsed2.pathname;\n }\n\n /** 比较两个URL是否完全相同(包括查询参数和哈希) */\n compareUrlFull(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.fullPath === parsed2.fullPath;\n }\n\n /** 清除当前的 iframe 和 postmate 实例 */\n clear() {\n // 销毁 postmate 实例\n if (this.postmateParent) {\n this.postmateParent.destroy();\n this.postmateParent = null;\n }\n\n this.eventBus.getRoutes = null;\n this.eventBus.route_update_result = null;\n this.childRoutes = [];\n this.childSupportsRouteUpdate = false;\n\n // 移除 iframe\n if (this.currentIframe && this.currentIframe.parentNode) {\n this.currentIframe.parentNode.removeChild(this.currentIframe);\n }\n this.currentIframe = null;\n }\n\n /** 初始化 */\n async init(callback: any = null) {\n // 清除之前的实例和 iframe\n this.clear();\n\n // 重置子页面路由更新支持标记\n this.childSupportsRouteUpdate = false;\n\n // 如果没有容器,或集成链接\n if (!this.iframeEle || !this.currentUrl) {\n this.destroy();\n return;\n }\n\n // 获取 iframe 容器\n const container: any =\n typeof this.iframeEle === 'function' ? this.iframeEle() : this.iframeEle;\n if (!container) {\n console.warn('【ParentPostmate】无法获取 iframe 容器');\n return;\n }\n\n // 创建 Postmate 实例(作为父)\n const handshake: any = new Postmate({\n container,\n url: this.currentUrl,\n name: '',\n model: '',\n });\n\n // 存储当前创建的 iframe\n this.currentIframe = container.querySelector('iframe');\n this.currentIframe.setAttribute('frameborder', '0');\n this.currentIframe.setAttribute('allow', 'fullscreen');\n this.currentIframe.addEventListener('load', () => {\n this.loadFunction && this.loadFunction();\n });\n\n handshake\n .then((parent: any) => {\n this.postmateParent = parent;\n\n // 监听子页面发来的获取数据请求\n parent.on('requestBaseData', () => {\n // 发送相关数据\n this.sendData();\n });\n\n // 监听子页面发来的路由配置数据\n parent.on('pushRoutes', (routes: string) => {\n if (routes) this.childRoutes = JSON.parse(routes);\n else this.childRoutes = [];\n this.eventBus.getRoutes && this.eventBus.getRoutes();\n });\n\n // 监听子页面的路由效验结果\n parent.on('routeExists', (flag: boolean) => {});\n\n // 监听子页面的动态路由变更支持\n parent.on('route_update_support', (flag: boolean) => {\n this.childSupportsRouteUpdate = flag;\n });\n\n // 监听子页面的路由变更结果\n parent.on('route_update_result', (flag: boolean) => {\n this.eventBus.route_update_result && this.eventBus.route_update_result(flag);\n });\n\n // 监听子页面发来的其他请求\n parent.on('otherRequest', (params: any) => {\n this.handleOtherRequest && this.handleOtherRequest(params);\n });\n\n if (typeof callback === 'function') callback();\n })\n .catch((error: any) => {\n console.error('【ParentPostmate】Postmate 连接失败:', error);\n });\n }\n\n /** 设置load执行事件 */\n setLoadFunction(loadFunction: () => void) {\n this.loadFunction = loadFunction;\n }\n\n /** 设置 iframe url */\n setIframeUrl(iframeUrl: string, routerPath: string = '') {\n // 如果完全一样:不操作\n if (iframeUrl === this.currentUrl) return;\n\n // 如果传入了路由,则对路径进行规范处理\n if (routerPath && !routerPath.startsWith('/')) {\n routerPath = '/' + routerPath;\n }\n\n if (routerPath && routerPath.endsWith('/')) {\n routerPath = routerPath.slice(0, -1);\n }\n\n // 1、传入的地址为空:销毁当前实例\n if (!iframeUrl) {\n this.currentUrl = '';\n this.destroy();\n console.error('【ParentPostmate】无加载地址,无法初始化');\n return;\n }\n\n // 2、如果当前无连接:直接设置并初始化\n if (!this.postmateParent || !this.currentUrl) {\n this.currentUrl = iframeUrl;\n if (this.iframeEle) this.init();\n else console.error('【ParentPostmate】无 iframe 容器,无法初始化');\n return;\n }\n\n // 3、如果当前系统不支持路由更新 或 新旧系统协议、ip、端口不同则重新初始化: 重新初始化\n if (\n !this.childSupportsRouteUpdate ||\n !this.childRoutes?.length ||\n !areUrlsSameProtocolIpPort(this.currentUrl, iframeUrl)\n ) {\n this.currentUrl = iframeUrl;\n this.init();\n return;\n }\n\n /**\n * 因新旧地址的基础地址完全相同,且已加载系统支持路由更新\n * 下面处理新旧地址的url,研判操作方式\n **/\n // 更新路由列表\n let flag = false;\n this.eventBus.getRoutes = () => {\n flag = true;\n this.handleSimilarUrl(iframeUrl, routerPath);\n };\n this.postmateParent.call('getRoutes');\n\n setTimeout(() => {\n if (flag) return;\n this.handleSimilarUrl(iframeUrl, routerPath);\n }, 1000);\n }\n\n // 处理相似地址\n handleSimilarUrl(iframeUrl: string, routerPath?: string) {\n this.currentUrl = iframeUrl;\n\n // 1 如果传入了routerPath,将该值与子系统匹配,判断是否可以直接跳转\n if (routerPath && checkPathInRoutes(this.childRoutes, routerPath)) {\n // 触发更新路由\n this.sendRouteUpdate({\n fullPath: routerPath,\n });\n return;\n }\n\n // 2 通过已加载子系统的路由列表匹配新链接的尾部路径,如果匹配到,则触发路由更新\n let isEnd = false;\n let noQueryUrl = iframeUrl.split('?')[0];\n this.childRoutes.forEach((v) => {\n if (noQueryUrl.endsWith(v.path)) {\n // 触发更新路由\n this.sendRouteUpdate({\n fullPath: v.path,\n });\n isEnd = true;\n return;\n }\n });\n if (isEnd) return;\n\n // 3 如果以上两种情况都不满足,则重新初始化\n this.init();\n }\n\n /** 向子页面发送路由更新消息 */\n sendRouteUpdate(parsedUrl: any) {\n try {\n let flag = false;\n this.eventBus.route_update_result = (state: boolean) => {\n flag = state;\n this.loadFunction && this.loadFunction();\n };\n this.postmateParent.call('routeUpdate', JSON.stringify(parsedUrl));\n console.log(\n '---------------------- 【ParentPostmate】推送路由更新 ----------------------',\n );\n setTimeout(() => {\n if (flag) return;\n console.warn('【ParentPostmate】推送路由更新失败,将重新初始化iframe');\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }, 1000);\n } catch (error) {\n console.warn('【ParentPostmate】发送路由更新消息失败,将重新初始化iframe:', error);\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }\n }\n\n /** 向子页面发送消息 */\n sendData() {\n if (!this.postmateParent) return;\n this.postmateParent.call('baseData', JSON.stringify(this.dataInfo));\n }\n\n /** 销毁实例 */\n destroy() {\n this.clear();\n }\n}\n"],"names":["MESSAGE_TYPE","uid","allowedPostmateTypes","isValidMessage","event","allowedOrigin","ParentAPI","config","value","name","data","property","Postmate","resolve","id","handler","method","callback","ChildAPI","postmate","result","res","eventName","container","model","url","classListArray","origin","link","protocol","host","attemptCount","interval","reject","listener","send","init","Model","parentModel","key","checkPathInRoutes","routes","path","route","isRouteExists","router","getRouterPaths","purifyRoute","safeFields","child","areUrlsSameProtocolIpPort","url1","url2","parsedUrl1","parsedUrl2","sameProtocol","sameHost","samePort","error","getCircularReplacer","seen","ChildPostmate","eventObj","routeUpdateCallback","that","arr","routePath","routeInfoStr","routeInfo","parent","err","params","ParentPostmate","dataInfo","iframeEle","iframeUrl","handleOtherRequest","port","pathname","search","hash","fullPath","url1End","url2End","parsed1","parsed2","handshake","flag","loadFunction","routerPath","_a","isEnd","noQueryUrl","v","parsedUrl","state"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../packages/postMeta/postMeta.js","../packages/postMeta/RouteMatching.ts","../packages/postMeta/tools.ts","../packages/postMeta/ChildPostmate.ts","../packages/postMeta/ParentPostmate.ts"],"sourcesContent":["const MESSAGE_TYPE = \"application/x-postmate-v1+json\";\nlet uid = 0;\n\nconst allowedPostmateTypes = {\n handshake: 1,\n \"handshake-reply\": 1,\n call: 1,\n emit: 1,\n reply: 1,\n request: 1,\n};\n\n// 校验消息是否来自合法的来源\nfunction isValidMessage(event, allowedOrigin) {\n return (\n (typeof allowedOrigin !== \"string\" || event.origin === allowedOrigin) &&\n !!event.data &&\n (typeof event.data !== \"object\" || \"postmate\" in event.data) &&\n event.data.type === MESSAGE_TYPE &&\n !!allowedPostmateTypes[event.data.postmate]\n );\n}\n\n// ----------------- ParentAPI -----------------\nclass ParentAPI {\n constructor(config) {\n this.parent = config.parent;\n this.frame = config.frame;\n this.child = config.child;\n this.childOrigin = config.childOrigin;\n this.events = {};\n\n this.listener = (event) => {\n if (!isValidMessage(event, this.childOrigin)) return;\n const { value = {} } = event.data;\n const { name, data } = value;\n if (event.data.postmate === \"emit\" && name in this.events) {\n this.events[name].call(this, data);\n }\n };\n\n this.parent.addEventListener(\"message\", this.listener, false);\n }\n\n get(property) {\n return new Postmate.Promise((resolve) => {\n const id = ++uid;\n const handler = (event) => {\n if (event.data.uid === id && event.data.postmate === \"reply\") {\n this.parent.removeEventListener(\"message\", handler, false);\n resolve(event.data.value);\n }\n };\n this.parent.addEventListener(\"message\", handler, false);\n this.child.postMessage(\n {\n postmate: \"request\",\n type: MESSAGE_TYPE,\n property,\n uid: id,\n },\n this.childOrigin\n );\n });\n }\n\n call(method, data) {\n this.child.postMessage(\n {\n postmate: \"call\",\n type: MESSAGE_TYPE,\n property: method,\n data,\n },\n this.childOrigin\n );\n }\n\n on(event, callback) {\n this.events[event] = callback;\n }\n\n destroy() {\n window.removeEventListener(\"message\", this.listener, false);\n this.frame.parentNode.removeChild(this.frame);\n }\n}\n\n// ----------------- ChildAPI -----------------\nclass ChildAPI {\n constructor(config) {\n this.model = config.model;\n this.parent = config.parent;\n this.parentOrigin = config.parentOrigin;\n this.child = config.child;\n\n this.child.addEventListener(\"message\", (event) => {\n if (!isValidMessage(event, this.parentOrigin)) return;\n\n const { postmate, property, uid, data } = event.data;\n const value = this.model[property];\n\n if (postmate !== \"call\") {\n const result = typeof value === \"function\" ? value() : value;\n Postmate.Promise.resolve(result).then((res) => {\n event.source.postMessage(\n {\n property,\n postmate: \"reply\",\n type: MESSAGE_TYPE,\n uid,\n value: res,\n },\n event.origin\n );\n });\n } else if (property in this.model && typeof value === \"function\") {\n value(data);\n }\n });\n }\n\n emit(eventName, data) {\n this.parent.postMessage(\n {\n postmate: \"emit\",\n type: MESSAGE_TYPE,\n value: { name: eventName, data },\n },\n this.parentOrigin\n );\n }\n}\n\n// ----------------- Postmate -----------------\nclass Postmate {\n constructor({ container = document.body, model, url, name, classListArray = [] }) {\n this.parent = window;\n this.frame = document.createElement(\"iframe\");\n this.frame.name = name || \"\";\n this.frame.classList.add(...classListArray);\n container.appendChild(this.frame);\n\n this.child = this.frame.contentWindow;\n this.model = model || {};\n\n return this.sendHandshake(url);\n }\n\n sendHandshake(url) {\n const origin = (() => {\n const link = document.createElement(\"a\");\n link.href = url;\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n const host = link.host.length ? (link.port === \"80\" || link.port === \"443\" ? link.hostname : link.host) : window.location.host;\n return link.origin || `${protocol}//${host}`;\n })();\n\n let attemptCount = 0;\n let interval;\n\n return new Postmate.Promise((resolve, reject) => {\n const listener = (event) => {\n if (!isValidMessage(event, origin)) return false;\n if (event.data.postmate === \"handshake-reply\") {\n clearInterval(interval);\n this.parent.removeEventListener(\"message\", listener, false);\n this.childOrigin = event.origin;\n resolve(new ParentAPI(this));\n } else {\n reject(\"Failed handshake\");\n }\n };\n\n this.parent.addEventListener(\"message\", listener, false);\n\n const send = () => {\n attemptCount++;\n this.child.postMessage(\n {\n postmate: \"handshake\",\n type: MESSAGE_TYPE,\n model: this.model,\n },\n origin\n );\n if (attemptCount === 5) clearInterval(interval);\n };\n\n const init = () => {\n send();\n interval = setInterval(send, 500);\n };\n\n this.frame.onload = init;\n this.frame.attachEvent && this.frame.attachEvent(\"onload\", init);\n this.frame.src = url;\n });\n }\n}\n\n// ----------------- Model -----------------\nclass Model {\n constructor(model) {\n this.child = window;\n this.model = model;\n this.parent = window.parent;\n\n return this.sendHandshakeReply();\n }\n\n sendHandshakeReply() {\n return new Postmate.Promise((resolve, reject) => {\n this.child.addEventListener(\"message\", (event) => {\n if (event.data.postmate) {\n if (event.data.postmate !== \"handshake\") return reject(\"Handshake Reply Failed\");\n\n this.child.removeEventListener(\"message\", this, false);\n event.source.postMessage(\n {\n postmate: \"handshake-reply\",\n type: MESSAGE_TYPE,\n },\n event.origin\n );\n\n this.parentOrigin = event.origin;\n const parentModel = event.data.model;\n if (parentModel) {\n Object.keys(parentModel).forEach((key) => {\n this.model[key] = parentModel[key];\n });\n }\n resolve(new ChildAPI(this));\n }\n }, false);\n });\n }\n}\n\n// Attach defaults\nPostmate.debug = false;\nPostmate.Promise = (() => {\n try {\n return typeof window !== \"undefined\" ? window.Promise : Promise;\n } catch {\n return Promise;\n }\n})();\nPostmate.Model = Model;\n\nexport default Postmate;\nexport { Model };\n","import type { RouteRecordRaw } from 'vue-router';\r\n\r\n/**\r\n * 标准化基础路由(base):确保以 / 开头,不以 / 结尾(空字符串除外)\r\n */\r\nconst normalizeBase = (base: string): string => {\r\n if (!base || base === '/') return '';\r\n const trimmed = base.replace(/\\/$/, '');\r\n return trimmed.startsWith('/') ? trimmed : `/${trimmed}`;\r\n};\r\n\r\n/**\r\n * 从全量地址中提取「相对于base的路由路径」\r\n */\r\nconst extractRelativePath = (fullAddress: string, base = ''): string | null => {\r\n if (!fullAddress) return null;\r\n const normalizedBase = normalizeBase(base);\r\n let pathname = '';\r\n\r\n try {\r\n const url = new URL(fullAddress);\r\n pathname = url.pathname;\r\n } catch {\r\n pathname = fullAddress.split(/[?#]/)[0];\r\n }\r\n\r\n // 1. 去重斜杠 + 标准化路径(核心:避免//导致的匹配问题)\r\n const normalizedPathname = pathname.replace(/\\/+/g, '/').replace(/\\/$/, '') || '/';\r\n\r\n if (normalizedBase && !normalizedPathname.startsWith(normalizedBase)) {\r\n return null;\r\n }\r\n\r\n let relativePath = normalizedBase\r\n ? normalizedPathname.slice(normalizedBase.length)\r\n : normalizedPathname;\r\n\r\n // 确保相对路径以/开头,且无重复斜杠\r\n relativePath = relativePath.replace(/\\/+/g, '/');\r\n relativePath = relativePath.startsWith('/') ? relativePath : `/${relativePath}`;\r\n return relativePath === '' ? '/' : relativePath;\r\n};\r\n\r\n/**\r\n * 核心修复:路由路径转正则(解决重复斜杠+动态参数匹配)\r\n * 关键优化:复用路径中原有的/,不再额外生成/\r\n */\r\nconst convertRoutePathToRegex = (routePath: string): RegExp => {\r\n if (!routePath) return /^$/iu;\r\n\r\n // 步骤1:标准化路由路径(去重斜杠 + 去除末尾斜杠)\r\n const normalizedRoutePath =\r\n routePath\r\n .replace(/\\/+/g, '/') // 去重所有重复斜杠(// → /)\r\n .replace(/\\/$/, '') || '/';\r\n\r\n // 步骤2:先转义原始路径的正则特殊字符(仅转义非动态参数部分)\r\n let regexStr = normalizedRoutePath.replace(/([.?+^$[\\](){}|-])/g, '\\\\$1');\r\n\r\n // 步骤3:处理动态路由语法(核心:不复用原有/,不再额外加/)\r\n regexStr = regexStr\r\n // 1. 通配符 :pathMatch(.*)* → 匹配任意多级路径(复用原有/)\r\n .replace(/:pathMatch\\\\\\(\\.\\*\\\\\\)\\*/g, '.+')\r\n // 2. 带正则约束的参数(如 :id(\\\\d+) → 保留正则,不复用原有/)\r\n .replace(/:([a-zA-Z0-9_]+)\\\\\\(([^)]+)\\\\\\)/g, (_, __, regex) => regex.replace(/\\\\\\\\/g, '\\\\'))\r\n // 3. 可选动态参数(如 :id? → 匹配 空 或 非/字符,复用原有/)\r\n .replace(/:([a-zA-Z0-9_]+)\\?/g, '[^/]*')\r\n // 4. 普通动态参数(核心修复:仅匹配非/字符,不复用原有/)\r\n .replace(/:([a-zA-Z0-9_]+)/g, '[^/]+');\r\n\r\n // 步骤4:拼接完整正则(确保无重复斜杠)\r\n regexStr = regexStr.replace(/\\/+/g, '\\\\/'); // 转义/,且去重\r\n return new RegExp(`^${regexStr}$`, 'iu');\r\n};\r\n\r\n/**\r\n * 递归遍历路由(保留调试日志)\r\n */\r\nconst traverseRoutes = (\r\n routers: RouteRecordRaw[],\r\n targetRelativePath: string,\r\n parentPath = '',\r\n): boolean => {\r\n // 目标路径去重斜杠 + 标准化\r\n const normalizedTarget = targetRelativePath.replace(/\\/+/g, '/').replace(/\\/$/, '') || '/';\r\n\r\n for (const route of routers) {\r\n // 修复嵌套路由拼接逻辑(彻底避免重复斜杠)\r\n const processedParentPath = parentPath.replace(/\\/+/g, '/').replace(/\\/$/, '');\r\n const processedRoutePath = route.path.replace(/\\/+/g, '/').replace(/^\\//, '');\r\n const fullRoutePath = processedParentPath\r\n ? `${processedParentPath}/${processedRoutePath}`.replace(/\\/+/g, '/')\r\n : route.path.replace(/\\/+/g, '/');\r\n\r\n const routeRegex = convertRoutePathToRegex(fullRoutePath);\r\n const isMatched = routeRegex.test(normalizedTarget);\r\n\r\n if (isMatched) return true;\r\n\r\n if (route.children && route.children.length) {\r\n const childMatched = traverseRoutes(route.children, normalizedTarget, fullRoutePath);\r\n if (childMatched) return true;\r\n }\r\n }\r\n\r\n return false;\r\n};\r\n\r\n/**\r\n * 对外方法\r\n */\r\nexport const isRouteMatched = (\r\n routers: RouteRecordRaw[],\r\n fullAddress: string,\r\n base = '',\r\n): boolean => {\r\n if (!routers || !routers.length || !fullAddress) return false;\r\n const relativePath = extractRelativePath(fullAddress, base);\r\n if (!relativePath) return false;\r\n return traverseRoutes(routers, relativePath);\r\n};\r\n","import { isRouteMatched } from './RouteMatching';\n\n/**\n * 检查路径是否存在于路由配置中(递归检查所有层级)\n * @param routes 路由配置数组\n * @param path 需要检查的路径\n * @returns 是否存在\n */\nexport function checkPathInRoutes(routes: any[], path: string): boolean {\n\tfor (const route of routes) {\n\t\t// 检查当前路由\n\t\tif (route.path === path) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// 递归检查子路由\n\t\tif (route.children && Array.isArray(route.children) && route.children.length > 0) {\n\t\t\tif (checkPathInRoutes(route.children, path)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n}\n\n/**\n * 判断路径是否存在于vue-router对象中(兼容Vue2和Vue3)\n * @param router vue-router实例\n * @param path 需要检查的页面路径\n * @returns 路径是否存在\n */\nexport function isRouteExists(router: any, path: string): boolean {\n\t// 移除路径中的查询参数\n\tif (path.includes('?')) {\n\t\tpath = path.split('?')[0];\n\t}\n\tconst routes = getRouterPaths(router);\n\tif (!routes || routes.length === 0) return false;\n\treturn checkPathInRoutes(routes, path);\n}\n\n// 净化单个路由配置,只保留安全字段\nfunction purifyRoute(route) {\n\t// 只提取需要的基础字段,根据你的需求调整\n\tconst safeFields = {\n\t\tpath: route.path,\n\t\tname: route.name,\n\t\tmeta: route.meta || {}, // 确保meta是普通对象\n\t\tredirect: route.redirect,\n\t\t// 剔除 component、beforeEnter 等可能包含函数/对象引用的字段\n\t\t// 如果需要children,递归净化\n\t\tchildren: route.children ? route.children.map((child) => purifyRoute(child)) : [],\n\t};\n\n\t// 进一步净化meta(如果meta中可能有复杂对象)\n\tsafeFields.meta = JSON.parse(JSON.stringify(safeFields.meta));\n\n\treturn safeFields;\n}\n\n/**\n * 获取路由路径\n *\n */\nexport function getRouterPaths(router: any): any[] {\n\tlet routes: any[] = [];\n\t// 区分Vue Router 3.x (Vue2) 和 4.x (Vue3)\n\tif (typeof router.getRoutes === 'function') {\n\t\t// Vue Router 4.x (Vue3)\n\t\troutes = router.getRoutes();\n\t} else if (router.options && Array.isArray(router.options.routes)) {\n\t\t// Vue Router 3.x (Vue2)\n\t\troutes = router.options.routes;\n\t}\n\treturn routes.map((route) => purifyRoute(route)) || [];\n}\n\n/**\n * 比较两个URL的协议、IP(或域名)和端口是否完全相同\n * @param url1 第一个URL字符串\n * @param url2 第二个URL字符串\n * @returns 如果协议、IP(或域名)和端口都相同则返回true,否则返回false;解析失败时返回false\n */\nexport function areUrlsSameProtocolIpPort(url1: string, url2: string): boolean {\n\ttry {\n\t\t// 解析两个URL\n\t\tconst parsedUrl1 = new URL(url1);\n\t\tconst parsedUrl2 = new URL(url2);\n\n\t\t// 比较协议(不区分大小写,但通常URL协议是小写的)\n\t\tconst sameProtocol = parsedUrl1.protocol.toLowerCase() === parsedUrl2.protocol.toLowerCase();\n\n\t\t// 比较主机(IP或域名)\n\t\tconst sameHost = parsedUrl1.hostname === parsedUrl2.hostname;\n\n\t\t// 比较端口(如果未指定端口,会使用协议默认端口)\n\t\tconst samePort = parsedUrl1.port === parsedUrl2.port;\n\n\t\t// 只有所有部分都相同时才返回true\n\t\treturn sameProtocol && sameHost && samePort;\n\t} catch (error) {\n\t\t// 如果URL解析失败,返回false\n\t\tconsole.error('URL解析错误:', error);\n\t\treturn false;\n\t}\n}\n\nexport const getCircularReplacer = () => {\n\tconst seen = new WeakSet();\n\treturn (key, value) => {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tif (seen.has(value)) {\n\t\t\t\t// 遇到循环引用时,返回一个标识或忽略\n\t\t\t\treturn '[Circular Reference]';\n\t\t\t}\n\t\t\tseen.add(value);\n\t\t}\n\t\treturn value;\n\t};\n};\n\nexport function getBaseRoute(routers: any[], url: string): string {\n\tlet baseRoute = '';\n\tlet urlObj = new URL(url);\n\tlet noQueryUrl = url.split('?')[0];\n\n\t// 判断路由模式并取值\n\tlet routePath = '';\n\tif (urlObj.hash && urlObj.hash.indexOf('#/') > -1) {\n\t\troutePath = urlObj.hash.split('#')[1];\n\n\t} else {\n\t\troutePath = urlObj.pathname;\n\t}\n\n\tconsole.log(routePath);\n\t\n\t// 当前路由中没有该路由,判定有base\n\tif (!isRouteMatched(routers, routePath)) {\n\t\t// 尝试剔除第一个路由,再判断是否匹配\n\t\tlet arr = routePath.split('/');\n\t\tlet nowRoute = '/' + arr.slice(2, arr.length).join('/');\n\t\tconsole.log(routers, nowRoute);\n\t\t\n\t\tif (isRouteMatched(routers, nowRoute)) {\n\t\t\tbaseRoute = '/' + arr[1];\n\t\t} else {\n\t\t\tconsole.error('仅支持vue-router一级base配置');\n\t\t}\n\t}\n\treturn baseRoute;\n}\n","import Postmate from './postMeta';\nimport { getCircularReplacer, getRouterPaths, isRouteExists } from './tools';\n\ninterface EventObj {\n\terror: (error: any) => void;\n\tsuccess: (success: any) => void;\n\treceive: (receive: any) => void;\n}\n\n// 路由更新接口\ninterface RouteUpdateInfo {\n\tfullPath: string;\n\t[x: string]: any;\n}\n\nexport default class ChildPostmate {\n\tchildPostmate: any = null;\n\tparentPostmate: any = null;\n\n\tisGetData: boolean = false;\n\tgetDataCllBack: Function | null = null;\n\tstateOver: boolean = false;\n\n\t// Vue Router实例\n\trouter: any = null;\n\t// 路由更新回调函数\n\tcustomRouteChange: ((routeInfo: RouteUpdateInfo) => void) | undefined = undefined;\n\n\tconstructor(eventObj: EventObj, router: any, customRouteChange?: (routeInfo: RouteUpdateInfo) => void) {\n\t\t// 保存router实例\n\t\tthis.router = router;\n\t\t// 保存路由更新回调函数\n\t\tthis.customRouteChange = customRouteChange;\n\n\t\tif (window.top !== window.self) {\n\t\t\tthis.init(eventObj);\n\t\t\tsetTimeout(() => {\n\t\t\t\tif (this.stateOver) return;\n\t\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t\t}, 500);\n\t\t} else {\n\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t}\n\t}\n\n\tinit(eventObj: EventObj) {\n\t\tconst that = this;\n\t\t// 创建 Postmate Model(作为子)\n\t\tthis.childPostmate = new Postmate.Model({\n\t\t\t// 定义子页面可以暴露给父页面的方法\n\t\t\tbaseData(data: any) {\n\t\t\t\tdata = JSON.parse(data);\n\t\t\t\tif (that.isGetData) {\n\t\t\t\t\tthat.getDataCllBack &&\n\t\t\t\t\t\tthat.getDataCllBack({\n\t\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\t\tdata: data,\n\t\t\t\t\t\t});\n\t\t\t\t} else\n\t\t\t\t\teventObj.receive({\n\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\tdata: data,\n\t\t\t\t\t});\n\t\t\t\tthat.isGetData = false;\n\t\t\t},\n\n\t\t\t// 提供当前系统的路由\n\t\t\tgetRoutes: () => {\n\t\t\t\t// 有路由\n\t\t\t\tif (that.router) {\n\t\t\t\t\tlet arr = getRouterPaths(that.router);\n\t\t\t\t\tthat.parentPostmate.emit('pushRoutes', JSON.stringify(arr, getCircularReplacer()));\n\t\t\t\t}\n\t\t\t\t// 无路由\n\t\t\t\telse that.parentPostmate.emit('pushRoutes');\n\t\t\t},\n\n\t\t\t// 检查路由是否存在\n\t\t\tisRouteExists(routePath: string) {\n\t\t\t\tif (that.router) that.parentPostmate.emit('routeExists', isRouteExists(that.router, routePath));\n\t\t\t\telse that.parentPostmate.emit('routeExists', false);\n\t\t\t},\n\n\t\t\t// 处理路由更新\n\t\t\trouteUpdate(routeInfoStr: string) {\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\ttry {\n\t\t\t\t\tconst routeInfo: RouteUpdateInfo = JSON.parse(routeInfoStr);\n\n\t\t\t\t\t// 如果提供了自定义的路由更新回调函数,则调用它\n\t\t\t\t\tif (that.customRouteChange) {\n\t\t\t\t\t\tthat.customRouteChange(routeInfo);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t// 如果提供了router实例,则使用router进行路由更新\n\t\t\t\t\tif (that.router) {\n\t\t\t\t\t\tthat.router.replace(routeInfo.fullPath);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t\t\tconsole.warn('【ChildPastMate】未提供router实例,无法进行路由更新');\n\t\t\t\t\t}\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsole.error('【ChildPastMate】路由更新失败:', error);\n\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t}\n\t\t\t},\n\t\t})\n\t\t\t.then((parent: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\tthat.parentPostmate = parent;\n\t\t\t\tthat.getData();\n\t\t\t\t// 与父页面链接建立成功\n\t\t\t\teventObj.success({\n\t\t\t\t\tstatus: 200,\n\t\t\t\t\tmessage: 'success',\n\t\t\t\t\tdata: {\n\t\t\t\t\t\tChildPostmate: parent,\n\t\t\t\t\t},\n\t\t\t\t});\n\t\t\t\t// 告诉父系统支持路由更新\n\t\t\t\tthat.parentPostmate.emit('route_update_support', that.router ? true : false);\n\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\tthat.router && that.parentPostmate.emit('pushRoutes', JSON.stringify(getRouterPaths(that.router), getCircularReplacer()));\n\t\t\t})\n\t\t\t.catch((err: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\teventObj.error({ status: 500, data: null, message: err });\n\t\t\t});\n\t}\n\n\t// 获取数据\n\tgetData(callback?: any) {\n\t\tif (!this.parentPostmate) {\n\t\t\tcallback({\n\t\t\t\tstatus: 500,\n\t\t\t\tmessage: '父页面未连接',\n\t\t\t\tdata: null,\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\n\t\tif (callback) {\n\t\t\tthis.isGetData = true;\n\t\t\tthis.getDataCllBack = callback;\n\t\t} else {\n\t\t\tthis.isGetData = false;\n\t\t\tthis.getDataCllBack = null;\n\t\t}\n\t\t// 向父页面获取数据\n\t\tthis.parentPostmate.emit('requestBaseData');\n\t}\n\n\t/**\n\t * 设置路由实例和路由更新回调\n\t * @param router Vue Router实例\n\t * @param customRouteChange 自定义路由更新回调函数\n\t */\n\tsetRouter(router: any, customRouteChange?: (routeInfo: RouteUpdateInfo) => void) {\n\t\tthis.router = router;\n\t\tif (customRouteChange) {\n\t\t\tthis.customRouteChange = customRouteChange;\n\t\t}\n\t}\n\n\t/**\n\t * 向父页面发送其他请求\n\t * @param params 请求参数\n\t */\n\tsendOtherRequest(params: any) {\n\t\tif (!this.parentPostmate) return;\n\t\tthis.parentPostmate.emit('otherRequest', params);\n\t}\n}\n","import Postmate from './postMeta';\nimport { isRouteMatched } from './RouteMatching';\nimport { areUrlsSameProtocolIpPort, checkPathInRoutes, getBaseRoute } from './tools';\n\ninterface DataInfo {\n loginInfo: { [x: string]: any };\n token: string;\n isHideHeader: boolean;\n}\n\n// URL解析结果接口\ninterface ParsedUrl {\n protocol: string;\n host: string;\n port: string;\n pathname: string;\n search: string;\n hash: string;\n origin: string;\n fullPath: string;\n}\n\nexport default class ParentPostmate {\n /** 连接到的子 postmate 实例 */\n postmateParent: any = null;\n /** 通讯数据 */\n dataInfo: DataInfo = {\n loginInfo: {},\n token: '',\n isHideHeader: true,\n };\n /** iframe Dom 容器 */\n iframeEle: any = null;\n /** 当前 iframe url */\n currentUrl: string = '';\n /** 存储当前的 iframe 元素 */\n currentIframe: any = null;\n /** iframe 加载完成执行函数 */\n loadFunction: (() => void) | null = null;\n /** 处理子类的其他请求方法 */\n handleOtherRequest: ((params: any) => void) | null = null;\n /** 子页面是否支持路由更新 */\n childSupportsRouteUpdate: boolean = true;\n /** 子系统的路由列表 */\n childRoutes: any[] = [];\n\n eventBus: any = {\n getRoutes: null,\n route_update_result: null,\n };\n\n constructor(\n dataInfo: DataInfo,\n iframeEle: HTMLElement | (() => HTMLElement),\n iframeUrl: string = '',\n handleOtherRequest?: (params: any) => void,\n ) {\n this.dataInfo = dataInfo || this.dataInfo;\n this.iframeEle = iframeEle;\n this.setIframeUrl(iframeUrl);\n handleOtherRequest && (this.handleOtherRequest = handleOtherRequest);\n }\n\n /** 解析URL */\n parseUrl(url: string): ParsedUrl {\n const link = document.createElement('a');\n link.href = url;\n\n // 获取协议\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n\n // 获取主机和端口\n const host = link.hostname;\n const port =\n link.port || (protocol === 'https:' ? '443' : protocol === 'http:' ? '80' : '');\n\n // 获取路径、查询参数和哈希\n const pathname = link.pathname.startsWith('/') ? link.pathname : `/${link.pathname}`;\n const search = link.search;\n const hash = link.hash.slice(2, link.hash.length);\n\n // 构建origin\n const origin = link.origin || `${protocol}//${host}${port ? `:${port}` : ''}`;\n\n // 构建完整路径(不包含origin)\n const fullPath = `${pathname}${hash}`;\n\n return {\n protocol,\n host,\n port,\n pathname,\n search,\n hash,\n origin,\n fullPath,\n };\n }\n\n /** 比较两个URL是否相同*/\n compareUrlBase(url1: string, url2: string): boolean {\n const url1End = url1.endsWith('/');\n const url2End = url2.endsWith('/');\n if ((url1End && url2End) || (!url1End && !url2End)) {\n return url1 === url2;\n } else {\n if (url1End) url2 += '/';\n if (url2End) url1 += '/';\n return url1 === url2;\n }\n }\n\n /** 比较两个URL的路径是否相同(不包含查询参数和哈希) */\n compareUrlPath(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.pathname === parsed2.pathname;\n }\n\n /** 比较两个URL是否完全相同(包括查询参数和哈希) */\n compareUrlFull(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.fullPath === parsed2.fullPath;\n }\n\n /** 清除当前的 iframe 和 postmate 实例 */\n clear() {\n // 销毁 postmate 实例\n if (this.postmateParent) {\n this.postmateParent.destroy();\n this.postmateParent = null;\n }\n\n this.eventBus.getRoutes = null;\n this.eventBus.route_update_result = null;\n this.childRoutes = [];\n this.childSupportsRouteUpdate = false;\n\n // 移除 iframe\n if (this.currentIframe && this.currentIframe.parentNode) {\n this.currentIframe.parentNode.removeChild(this.currentIframe);\n }\n this.currentIframe = null;\n }\n\n /** 初始化 */\n async init(callback: any = null) {\n // 清除之前的实例和 iframe\n this.clear();\n\n // 重置子页面路由更新支持标记\n this.childSupportsRouteUpdate = false;\n\n // 如果没有容器,或集成链接\n if (!this.iframeEle || !this.currentUrl) {\n this.destroy();\n return;\n }\n\n // 获取 iframe 容器\n const container: any =\n typeof this.iframeEle === 'function' ? this.iframeEle() : this.iframeEle;\n if (!container) {\n console.warn('【ParentPostmate】无法获取 iframe 容器');\n return;\n }\n\n // 创建 Postmate 实例(作为父)\n const handshake: any = new Postmate({\n container,\n url: this.currentUrl,\n name: '',\n model: '',\n });\n\n // 存储当前创建的 iframe\n this.currentIframe = container.querySelector('iframe');\n this.currentIframe.setAttribute('frameborder', '0');\n this.currentIframe.setAttribute('allow', 'fullscreen');\n this.currentIframe.addEventListener('load', () => {\n this.loadFunction && this.loadFunction();\n });\n\n handshake\n .then((parent: any) => {\n this.postmateParent = parent;\n\n // 监听子页面发来的获取数据请求\n parent.on('requestBaseData', () => {\n // 发送相关数据\n this.sendData();\n });\n\n // 监听子页面发来的路由配置数据\n parent.on('pushRoutes', (routes: string) => {\n if (routes) this.childRoutes = JSON.parse(routes);\n else this.childRoutes = [];\n this.eventBus.getRoutes && this.eventBus.getRoutes();\n });\n\n // 监听子页面的路由效验结果\n parent.on('routeExists', (flag: boolean) => {});\n\n // 监听子页面的动态路由变更支持\n parent.on('route_update_support', (flag: boolean) => {\n this.childSupportsRouteUpdate = flag;\n });\n\n // 监听子页面的路由变更结果\n parent.on('route_update_result', (flag: boolean) => {\n this.eventBus.route_update_result && this.eventBus.route_update_result(flag);\n });\n\n // 监听子页面发来的其他请求\n parent.on('otherRequest', (params: any) => {\n this.handleOtherRequest && this.handleOtherRequest(params);\n });\n\n if (typeof callback === 'function') callback();\n })\n .catch((error: any) => {\n console.error('【ParentPostmate】Postmate 连接失败:', error);\n });\n }\n\n /** 设置load执行事件 */\n setLoadFunction(loadFunction: () => void) {\n this.loadFunction = loadFunction;\n }\n\n /** 设置 iframe url */\n setIframeUrl(iframeUrl: string, routerPath: string = '') {\n // 如果完全一样:不操作\n if (iframeUrl === this.currentUrl) return;\n\n // 如果传入了路由,则对路径进行规范处理\n if (routerPath && !routerPath.startsWith('/')) {\n routerPath = '/' + routerPath;\n }\n\n if (routerPath && routerPath.endsWith('/')) {\n routerPath = routerPath.slice(0, -1);\n }\n\n // 1、传入的地址为空:销毁当前实例\n if (!iframeUrl) {\n this.currentUrl = '';\n this.destroy();\n console.error('【ParentPostmate】无加载地址,无法初始化');\n return;\n }\n\n // 2、如果当前无连接:直接设置并初始化\n if (!this.postmateParent || !this.currentUrl) {\n this.currentUrl = iframeUrl;\n if (this.iframeEle) this.init();\n else console.error('【ParentPostmate】无 iframe 容器,无法初始化');\n return;\n }\n\n // 3、如果当前系统不支持路由更新 或 新旧系统协议、ip、端口不同则重新初始化: 重新初始化\n if (\n !this.childSupportsRouteUpdate ||\n !this.childRoutes?.length ||\n !areUrlsSameProtocolIpPort(this.currentUrl, iframeUrl)\n ) {\n this.currentUrl = iframeUrl;\n this.init();\n return;\n }\n\n /**\n * 因新旧地址的基础地址完全相同,且已加载系统支持路由更新\n * 下面处理新旧地址的url,研判操作方式\n **/\n // 更新路由列表\n let flag = false;\n this.eventBus.getRoutes = () => {\n flag = true;\n this.handleSimilarUrl(iframeUrl, routerPath);\n };\n this.postmateParent.call('getRoutes');\n\n setTimeout(() => {\n if (flag) return;\n this.handleSimilarUrl(iframeUrl, routerPath);\n }, 1000);\n }\n\n // 处理相似地址\n handleSimilarUrl(iframeUrl: string, routerPath?: string) {\n let hasQuery = iframeUrl.split('?').length > 1;\n let urlQuery = '';\n // 判断是否携带参数\n if (hasQuery) urlQuery = '?' + iframeUrl.split('?')[1];\n\n // 1 如果传入了routerPath,将该值与子系统匹配,判断是否可以直接跳转\n if (routerPath && isRouteMatched(this.childRoutes, routerPath)) {\n this.sendRouteUpdate({\n fullPath: routerPath + urlQuery,\n });\n this.currentUrl = iframeUrl;\n return;\n }\n\n // 2 手动解析地址中的routePath,并考虑是否携带基础地址\n // 获取基础地址\n const baseRoute = getBaseRoute(this.childRoutes, this.currentUrl);\n // 获取新链接的路由地址\n let urlObj = new URL(iframeUrl);\n let routePath = '';\n if (urlObj.hash && urlObj.hash.indexOf('#/') > -1) {\n routePath = urlObj.hash.split('#')[1];\n } else {\n routePath = urlObj.pathname + urlQuery;\n }\n console.log(this.childRoutes, routePath.replace(baseRoute, ''));\n\n if (\n this.currentUrl.split(baseRoute)[0] === iframeUrl.split(baseRoute)[0] &&\n isRouteMatched(this.childRoutes, routePath.replace(baseRoute, ''))\n ) {\n // 触发更新路由\n this.sendRouteUpdate({\n fullPath: routePath.replace(baseRoute, ''),\n });\n console.log('推送地址:', iframeUrl);\n console.log('推送路由:', routePath.replace(baseRoute, ''));\n console.log('当前地址:', this.currentUrl);\n\n this.currentUrl = iframeUrl;\n return;\n }\n\n // 3 如果以上两种情况都不满足,则重新初始化\n this.currentUrl = iframeUrl;\n this.init();\n }\n\n /** 向子页面发送路由更新消息 */\n sendRouteUpdate(parsedUrl: any) {\n try {\n let flag = false;\n this.eventBus.route_update_result = (state: boolean) => {\n flag = state;\n this.loadFunction && this.loadFunction();\n };\n this.postmateParent.call('routeUpdate', JSON.stringify(parsedUrl));\n console.log(\n '---------------------- 【ParentPostmate】推送路由更新 ----------------------',\n );\n setTimeout(() => {\n if (flag) return;\n console.warn('【ParentPostmate】推送路由更新失败,将重新初始化iframe');\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }, 1000);\n } catch (error) {\n console.warn('【ParentPostmate】发送路由更新消息失败,将重新初始化iframe:', error);\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }\n }\n\n /** 向子页面发送消息 */\n sendData() {\n if (!this.postmateParent) return;\n this.postmateParent.call('baseData', JSON.stringify(this.dataInfo));\n }\n\n /** 销毁实例 */\n destroy() {\n this.clear();\n }\n}\n"],"names":["MESSAGE_TYPE","uid","allowedPostmateTypes","isValidMessage","event","allowedOrigin","ParentAPI","config","value","name","data","property","Postmate","resolve","id","handler","method","callback","ChildAPI","postmate","result","res","eventName","container","model","url","classListArray","origin","link","protocol","host","attemptCount","interval","reject","listener","send","init","Model","parentModel","key","normalizeBase","base","trimmed","extractRelativePath","fullAddress","normalizedBase","pathname","normalizedPathname","relativePath","convertRoutePathToRegex","routePath","regexStr","_","__","regex","traverseRoutes","routers","targetRelativePath","parentPath","normalizedTarget","route","processedParentPath","processedRoutePath","fullRoutePath","isRouteMatched","checkPathInRoutes","routes","path","isRouteExists","router","getRouterPaths","purifyRoute","safeFields","child","areUrlsSameProtocolIpPort","url1","url2","parsedUrl1","parsedUrl2","sameProtocol","sameHost","samePort","error","getCircularReplacer","seen","getBaseRoute","baseRoute","urlObj","arr","nowRoute","ChildPostmate","eventObj","customRouteChange","that","routeInfoStr","routeInfo","parent","err","params","ParentPostmate","dataInfo","iframeEle","iframeUrl","handleOtherRequest","port","search","hash","fullPath","url1End","url2End","parsed1","parsed2","handshake","flag","loadFunction","routerPath","_a","hasQuery","urlQuery","parsedUrl","state"],"mappings":"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"}
|
package/lib/index.umd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(function(u,o){typeof exports=="object"&&typeof module<"u"?o(exports):typeof define=="function"&&define.amd?define(["exports"],o):(u=typeof globalThis<"u"?globalThis:u||self,o(u["qlfy-postmate"]={}))})(this,function(u){"use strict";const o="application/x-postmate-v1+json";let R=0;const w={handshake:1,"handshake-reply":1,call:1,emit:1,reply:1,request:1};function m(i,e){return(typeof e!="string"||i.origin===e)&&!!i.data&&(typeof i.data!="object"||"postmate"in i.data)&&i.data.type===o&&!!w[i.data.postmate]}class U{constructor(e){this.parent=e.parent,this.frame=e.frame,this.child=e.child,this.childOrigin=e.childOrigin,this.events={},this.listener=t=>{if(!m(t,this.childOrigin))return;const{value:s={}}=t.data,{name:r,data:a}=s;t.data.postmate==="emit"&&r in this.events&&this.events[r].call(this,a)},this.parent.addEventListener("message",this.listener,!1)}get(e){return new l.Promise(t=>{const s=++R,r=a=>{a.data.uid===s&&a.data.postmate==="reply"&&(this.parent.removeEventListener("message",r,!1),t(a.data.value))};this.parent.addEventListener("message",r,!1),this.child.postMessage({postmate:"request",type:o,property:e,uid:s},this.childOrigin)})}call(e,t){this.child.postMessage({postmate:"call",type:o,property:e,data:t},this.childOrigin)}on(e,t){this.events[e]=t}destroy(){window.removeEventListener("message",this.listener,!1),this.frame.parentNode.removeChild(this.frame)}}class E{constructor(e){this.model=e.model,this.parent=e.parent,this.parentOrigin=e.parentOrigin,this.child=e.child,this.child.addEventListener("message",t=>{if(!m(t,this.parentOrigin))return;const{postmate:s,property:r,uid:a,data:h}=t.data,n=this.model[r];if(s!=="call"){const c=typeof n=="function"?n():n;l.Promise.resolve(c).then(d=>{t.source.postMessage({property:r,postmate:"reply",type:o,uid:a,value:d},t.origin)})}else r in this.model&&typeof n=="function"&&n(h)})}emit(e,t){this.parent.postMessage({postmate:"emit",type:o,value:{name:e,data:t}},this.parentOrigin)}}class l{constructor({container:e=document.body,model:t,url:s,name:r,classListArray:a=[]}){return this.parent=window,this.frame=document.createElement("iframe"),this.frame.name=r||"",this.frame.classList.add(...a),e.appendChild(this.frame),this.child=this.frame.contentWindow,this.model=t||{},this.sendHandshake(s)}sendHandshake(e){const t=(()=>{const a=document.createElement("a");a.href=e;const h=a.protocol.length>4?a.protocol:window.location.protocol,n=a.host.length?a.port==="80"||a.port==="443"?a.hostname:a.host:window.location.host;return a.origin||`${h}//${n}`})();let s=0,r;return new l.Promise((a,h)=>{const n=p=>{if(!m(p,t))return!1;p.data.postmate==="handshake-reply"?(clearInterval(r),this.parent.removeEventListener("message",n,!1),this.childOrigin=p.origin,a(new U(this))):h("Failed handshake")};this.parent.addEventListener("message",n,!1);const c=()=>{s++,this.child.postMessage({postmate:"handshake",type:o,model:this.model},t),s===5&&clearInterval(r)},d=()=>{c(),r=setInterval(c,500)};this.frame.onload=d,this.frame.attachEvent&&this.frame.attachEvent("onload",d),this.frame.src=e})}}class S{constructor(e){return this.child=window,this.model=e,this.parent=window.parent,this.sendHandshakeReply()}sendHandshakeReply(){return new l.Promise((e,t)=>{this.child.addEventListener("message",s=>{if(s.data.postmate){if(s.data.postmate!=="handshake")return t("Handshake Reply Failed");this.child.removeEventListener("message",this,!1),s.source.postMessage({postmate:"handshake-reply",type:o},s.origin),this.parentOrigin=s.origin;const r=s.data.model;r&&Object.keys(r).forEach(a=>{this.model[a]=r[a]}),e(new E(this))}},!1)})}}l.debug=!1,l.Promise=(()=>{try{return typeof window<"u"?window.Promise:Promise}catch{return Promise}})(),l.Model=S;function f(i,e){for(const t of i)if(t.path===e||t.children&&Array.isArray(t.children)&&t.children.length>0&&f(t.children,e))return!0;return!1}function k(i,e){e.includes("?")&&(e=e.split("?")[0]);const t=g(i);return!t||t.length===0?!1:f(t,e)}function P(i){const e={path:i.path,name:i.name,meta:i.meta||{},redirect:i.redirect,children:i.children?i.children.map(t=>P(t)):[]};return e.meta=JSON.parse(JSON.stringify(e.meta)),e}function g(i){let e=[];return typeof i.getRoutes=="function"?e=i.getRoutes():i.options&&Array.isArray(i.options.routes)&&(e=i.options.routes),e.map(t=>P(t))||[]}function C(i,e){try{const t=new URL(i),s=new URL(e),r=t.protocol.toLowerCase()===s.protocol.toLowerCase(),a=t.hostname===s.hostname,h=t.port===s.port;return r&&a&&h}catch(t){return console.error("URL解析错误:",t),!1}}const y=()=>{const i=new WeakSet;return(e,t)=>{if(typeof t=="object"&&t!==null){if(i.has(t))return"[Circular Reference]";i.add(t)}return t}};class I{constructor(e,t,s){this.childPostmate=null,this.parentPostmate=null,this.isGetData=!1,this.getDataCllBack=null,this.stateOver=!1,this.router=null,this.routeUpdateCallback=void 0,this.router=t,this.routeUpdateCallback=s,window.top!==window.self?(this.init(e),setTimeout(()=>{this.stateOver||e.error({status:500,data:null,message:"未在一体化平台中运行"})},500)):e.error({status:500,data:null,message:"未在一体化平台中运行"})}init(e){const t=this;this.childPostmate=new l.Model({baseData(s){s=JSON.parse(s),t.isGetData?t.getDataCllBack&&t.getDataCllBack({status:200,message:"success",data:s}):e.receive({status:200,message:"success",data:s}),t.isGetData=!1},getRoutes:()=>{if(t.router){let s=g(t.router);t.parentPostmate.emit("pushRoutes",JSON.stringify(s,y()))}else t.parentPostmate.emit("pushRoutes")},isRouteExists(s){t.router?t.parentPostmate.emit("routeExists",k(t.router,s)):t.parentPostmate.emit("routeExists",!1)},routeUpdate(s){try{const r=JSON.parse(s);if(t.routeUpdateCallback){t.routeUpdateCallback(r),t.parentPostmate.emit("route_update_result",!0),console.log("----------------- 【ChildPastMate】路由更新完成 -----------------");return}t.router?(t.router.replace(r.fullPath),t.parentPostmate.emit("route_update_result",!0),console.log("----------------- 【ChildPastMate】路由更新完成 -----------------")):(t.parentPostmate.emit("route_update_result",!1),console.warn("【ChildPastMate】未提供router实例,无法进行路由更新"))}catch(r){console.error("【ChildPastMate】路由更新失败:",r),t.parentPostmate.emit("route_update_result",!1)}}}).then(s=>{this.stateOver=!0,t.parentPostmate=s,t.getData(),e.success({status:200,message:"success",data:{ChildPostmate:s}}),t.parentPostmate.emit("route_update_support",!!t.router),t.router&&t.parentPostmate.emit("pushRoutes",JSON.stringify(g(t.router),y()))}).catch(s=>{this.stateOver=!0,e.error({status:500,data:null,message:s})})}getData(e){if(!this.parentPostmate){e({status:500,message:"父页面未连接",data:null});return}e?(this.isGetData=!0,this.getDataCllBack=e):(this.isGetData=!1,this.getDataCllBack=null),this.parentPostmate.emit("requestBaseData")}setRouter(e,t){this.router=e,t&&(this.routeUpdateCallback=t)}sendOtherRequest(e){this.parentPostmate&&this.parentPostmate.emit("otherRequest",e)}}class O{constructor(e,t,s="",r){this.postmateParent=null,this.dataInfo={loginInfo:{},token:"",isHideHeader:!0},this.iframeEle=null,this.currentUrl="",this.currentIframe=null,this.loadFunction=null,this.handleOtherRequest=null,this.childSupportsRouteUpdate=!0,this.childRoutes=[],this.eventBus={getRoutes:null,route_update_resultL:null},this.dataInfo=e||this.dataInfo,this.iframeEle=t,this.setIframeUrl(s),r&&(this.handleOtherRequest=r)}parseUrl(e){const t=document.createElement("a");t.href=e;const s=t.protocol.length>4?t.protocol:window.location.protocol,r=t.hostname,a=t.port||(s==="https:"?"443":s==="http:"?"80":""),h=t.pathname.startsWith("/")?t.pathname:`/${t.pathname}`,n=t.search,c=t.hash.slice(2,t.hash.length),d=t.origin||`${s}//${r}${a?`:${a}`:""}`,p=`${h}${c}`;return{protocol:s,host:r,port:a,pathname:h,search:n,hash:c,origin:d,fullPath:p}}compareUrlBase(e,t){const s=e.endsWith("/"),r=t.endsWith("/");return s&&r||!s&&!r||(s&&(t+="/"),r&&(e+="/")),e===t}compareUrlPath(e,t){if(!e||!t)return!1;const s=this.parseUrl(e),r=this.parseUrl(t);return s.pathname===r.pathname}compareUrlFull(e,t){if(!e||!t)return!1;const s=this.parseUrl(e),r=this.parseUrl(t);return s.fullPath===r.fullPath}clear(){this.postmateParent&&(this.postmateParent.destroy(),this.postmateParent=null),this.eventBus.getRoutes=null,this.eventBus.route_update_result=null,this.childRoutes=[],this.childSupportsRouteUpdate=!1,this.currentIframe&&this.currentIframe.parentNode&&this.currentIframe.parentNode.removeChild(this.currentIframe),this.currentIframe=null}async init(e=null){if(this.clear(),this.childSupportsRouteUpdate=!1,!this.iframeEle||!this.currentUrl){this.destroy();return}const t=typeof this.iframeEle=="function"?this.iframeEle():this.iframeEle;if(!t){console.warn("【ParentPostmate】无法获取 iframe 容器");return}const s=new l({container:t,url:this.currentUrl,name:"",model:""});this.currentIframe=t.querySelector("iframe"),this.currentIframe.setAttribute("frameborder","0"),this.currentIframe.setAttribute("allow","fullscreen"),this.currentIframe.addEventListener("load",()=>{this.loadFunction&&this.loadFunction()}),s.then(r=>{this.postmateParent=r,r.on("requestBaseData",()=>{this.sendData()}),r.on("pushRoutes",a=>{a?this.childRoutes=JSON.parse(a):this.childRoutes=[],this.eventBus.getRoutes&&this.eventBus.getRoutes()}),r.on("routeExists",a=>{}),r.on("route_update_support",a=>{this.childSupportsRouteUpdate=a}),r.on("route_update_result",a=>{this.eventBus.route_update_result&&this.eventBus.route_update_result(a)}),r.on("otherRequest",a=>{this.handleOtherRequest&&this.handleOtherRequest(a)}),typeof e=="function"&&e()}).catch(r=>{console.error("【ParentPostmate】Postmate 连接失败:",r)})}setLoadFunction(e){this.loadFunction=e}setIframeUrl(e,t=""){var r;if(e===this.currentUrl)return;if(t&&!t.startsWith("/")&&(t="/"+t),t&&t.endsWith("/")&&(t=t.slice(0,-1)),!e){this.currentUrl="",this.destroy(),console.error("【ParentPostmate】无加载地址,无法初始化");return}if(!this.postmateParent||!this.currentUrl){this.currentUrl=e,this.iframeEle?this.init():console.error("【ParentPostmate】无 iframe 容器,无法初始化");return}if(!this.childSupportsRouteUpdate||!((r=this.childRoutes)!=null&&r.length)||!C(this.currentUrl,e)){this.currentUrl=e,this.init();return}let s=!1;this.eventBus.getRoutes=()=>{s=!0,this.handleSimilarUrl(e,t)},this.postmateParent.call("getRoutes"),setTimeout(()=>{s||this.handleSimilarUrl(e,t)},1e3)}handleSimilarUrl(e,t){if(this.currentUrl=e,t&&f(this.childRoutes,t)){this.sendRouteUpdate({fullPath:t});return}let s=!1,r=e.split("?")[0];this.childRoutes.forEach(a=>{if(r.endsWith(a.path)){this.sendRouteUpdate({fullPath:a.path}),s=!0;return}}),!s&&this.init()}sendRouteUpdate(e){try{let t=!1;this.eventBus.route_update_result=s=>{t=s,this.loadFunction&&this.loadFunction()},this.postmateParent.call("routeUpdate",JSON.stringify(e)),console.log("---------------------- 【ParentPostmate】推送路由更新 ----------------------"),setTimeout(()=>{t||(console.warn("【ParentPostmate】推送路由更新失败,将重新初始化iframe"),this.childSupportsRouteUpdate=!1,this.init())},1e3)}catch(t){console.warn("【ParentPostmate】发送路由更新消息失败,将重新初始化iframe:",t),this.childSupportsRouteUpdate=!1,this.init()}}sendData(){this.postmateParent&&this.postmateParent.call("baseData",JSON.stringify(this.dataInfo))}destroy(){this.clear()}}u.ChildPostmate=I,u.ParentPostmate=O,Object.defineProperty(u,Symbol.toStringTag,{value:"Module"})});
|
|
1
|
+
(function(c,l){typeof exports=="object"&&typeof module<"u"?l(exports):typeof define=="function"&&define.amd?define(["exports"],l):(c=typeof globalThis<"u"?globalThis:c||self,l(c["qlfy-postmate"]={}))})(this,function(c){"use strict";const l="application/x-postmate-v1+json";let U=0;const E={handshake:1,"handshake-reply":1,call:1,emit:1,reply:1,request:1};function f(i,e){return(typeof e!="string"||i.origin===e)&&!!i.data&&(typeof i.data!="object"||"postmate"in i.data)&&i.data.type===l&&!!E[i.data.postmate]}class _{constructor(e){this.parent=e.parent,this.frame=e.frame,this.child=e.child,this.childOrigin=e.childOrigin,this.events={},this.listener=t=>{if(!f(t,this.childOrigin))return;const{value:s={}}=t.data,{name:r,data:a}=s;t.data.postmate==="emit"&&r in this.events&&this.events[r].call(this,a)},this.parent.addEventListener("message",this.listener,!1)}get(e){return new h.Promise(t=>{const s=++U,r=a=>{a.data.uid===s&&a.data.postmate==="reply"&&(this.parent.removeEventListener("message",r,!1),t(a.data.value))};this.parent.addEventListener("message",r,!1),this.child.postMessage({postmate:"request",type:l,property:e,uid:s},this.childOrigin)})}call(e,t){this.child.postMessage({postmate:"call",type:l,property:e,data:t},this.childOrigin)}on(e,t){this.events[e]=t}destroy(){window.removeEventListener("message",this.listener,!1),this.frame.parentNode.removeChild(this.frame)}}class O{constructor(e){this.model=e.model,this.parent=e.parent,this.parentOrigin=e.parentOrigin,this.child=e.child,this.child.addEventListener("message",t=>{if(!f(t,this.parentOrigin))return;const{postmate:s,property:r,uid:a,data:o}=t.data,n=this.model[r];if(s!=="call"){const u=typeof n=="function"?n():n;h.Promise.resolve(u).then(d=>{t.source.postMessage({property:r,postmate:"reply",type:l,uid:a,value:d},t.origin)})}else r in this.model&&typeof n=="function"&&n(o)})}emit(e,t){this.parent.postMessage({postmate:"emit",type:l,value:{name:e,data:t}},this.parentOrigin)}}class h{constructor({container:e=document.body,model:t,url:s,name:r,classListArray:a=[]}){return this.parent=window,this.frame=document.createElement("iframe"),this.frame.name=r||"",this.frame.classList.add(...a),e.appendChild(this.frame),this.child=this.frame.contentWindow,this.model=t||{},this.sendHandshake(s)}sendHandshake(e){const t=(()=>{const a=document.createElement("a");a.href=e;const o=a.protocol.length>4?a.protocol:window.location.protocol,n=a.host.length?a.port==="80"||a.port==="443"?a.hostname:a.host:window.location.host;return a.origin||`${o}//${n}`})();let s=0,r;return new h.Promise((a,o)=>{const n=p=>{if(!f(p,t))return!1;p.data.postmate==="handshake-reply"?(clearInterval(r),this.parent.removeEventListener("message",n,!1),this.childOrigin=p.origin,a(new _(this))):o("Failed handshake")};this.parent.addEventListener("message",n,!1);const u=()=>{s++,this.child.postMessage({postmate:"handshake",type:l,model:this.model},t),s===5&&clearInterval(r)},d=()=>{u(),r=setInterval(u,500)};this.frame.onload=d,this.frame.attachEvent&&this.frame.attachEvent("onload",d),this.frame.src=e})}}class v{constructor(e){return this.child=window,this.model=e,this.parent=window.parent,this.sendHandshakeReply()}sendHandshakeReply(){return new h.Promise((e,t)=>{this.child.addEventListener("message",s=>{if(s.data.postmate){if(s.data.postmate!=="handshake")return t("Handshake Reply Failed");this.child.removeEventListener("message",this,!1),s.source.postMessage({postmate:"handshake-reply",type:l},s.origin),this.parentOrigin=s.origin;const r=s.data.model;r&&Object.keys(r).forEach(a=>{this.model[a]=r[a]}),e(new O(this))}},!1)})}}h.debug=!1,h.Promise=(()=>{try{return typeof window<"u"?window.Promise:Promise}catch{return Promise}})(),h.Model=v;const S=i=>{if(!i||i==="/")return"";const e=i.replace(/\/$/,"");return e.startsWith("/")?e:`/${e}`},C=(i,e="")=>{if(!i)return null;const t=S(e);let s="";try{s=new URL(i).pathname}catch{s=i.split(/[?#]/)[0]}const r=s.replace(/\/+/g,"/").replace(/\/$/,"")||"/";if(t&&!r.startsWith(t))return null;let a=t?r.slice(t.length):r;return a=a.replace(/\/+/g,"/"),a=a.startsWith("/")?a:`/${a}`,a===""?"/":a},I=i=>{if(!i)return/^$/iu;let t=(i.replace(/\/+/g,"/").replace(/\/$/,"")||"/").replace(/([.?+^$[\](){}|-])/g,"\\$1");return t=t.replace(/:pathMatch\\\(\.\*\\\)\*/g,".+").replace(/:([a-zA-Z0-9_]+)\\\(([^)]+)\\\)/g,(s,r,a)=>a.replace(/\\\\/g,"\\")).replace(/:([a-zA-Z0-9_]+)\?/g,"[^/]*").replace(/:([a-zA-Z0-9_]+)/g,"[^/]+"),t=t.replace(/\/+/g,"\\/"),new RegExp(`^${t}$`,"iu")},P=(i,e,t="")=>{const s=e.replace(/\/+/g,"/").replace(/\/$/,"")||"/";for(const r of i){const a=t.replace(/\/+/g,"/").replace(/\/$/,""),o=r.path.replace(/\/+/g,"/").replace(/^\//,""),n=a?`${a}/${o}`.replace(/\/+/g,"/"):r.path.replace(/\/+/g,"/");if(I(n).test(s)||r.children&&r.children.length&&P(r.children,s,n))return!0}return!1},m=(i,e,t="")=>{if(!i||!i.length||!e)return!1;const s=C(e,t);return s?P(i,s):!1};function R(i,e){for(const t of i)if(t.path===e||t.children&&Array.isArray(t.children)&&t.children.length>0&&R(t.children,e))return!0;return!1}function M(i,e){e.includes("?")&&(e=e.split("?")[0]);const t=g(i);return!t||t.length===0?!1:R(t,e)}function y(i){const e={path:i.path,name:i.name,meta:i.meta||{},redirect:i.redirect,children:i.children?i.children.map(t=>y(t)):[]};return e.meta=JSON.parse(JSON.stringify(e.meta)),e}function g(i){let e=[];return typeof i.getRoutes=="function"?e=i.getRoutes():i.options&&Array.isArray(i.options.routes)&&(e=i.options.routes),e.map(t=>y(t))||[]}function $(i,e){try{const t=new URL(i),s=new URL(e),r=t.protocol.toLowerCase()===s.protocol.toLowerCase(),a=t.hostname===s.hostname,o=t.port===s.port;return r&&a&&o}catch(t){return console.error("URL解析错误:",t),!1}}const w=()=>{const i=new WeakSet;return(e,t)=>{if(typeof t=="object"&&t!==null){if(i.has(t))return"[Circular Reference]";i.add(t)}return t}};function k(i,e){let t="",s=new URL(e);e.split("?")[0];let r="";if(s.hash&&s.hash.indexOf("#/")>-1?r=s.hash.split("#")[1]:r=s.pathname,console.log(r),!m(i,r)){let a=r.split("/"),o="/"+a.slice(2,a.length).join("/");console.log(i,o),m(i,o)?t="/"+a[1]:console.error("仅支持vue-router一级base配置")}return t}class B{constructor(e,t,s){this.childPostmate=null,this.parentPostmate=null,this.isGetData=!1,this.getDataCllBack=null,this.stateOver=!1,this.router=null,this.customRouteChange=void 0,this.router=t,this.customRouteChange=s,window.top!==window.self?(this.init(e),setTimeout(()=>{this.stateOver||e.error({status:500,data:null,message:"未在一体化平台中运行"})},500)):e.error({status:500,data:null,message:"未在一体化平台中运行"})}init(e){const t=this;this.childPostmate=new h.Model({baseData(s){s=JSON.parse(s),t.isGetData?t.getDataCllBack&&t.getDataCllBack({status:200,message:"success",data:s}):e.receive({status:200,message:"success",data:s}),t.isGetData=!1},getRoutes:()=>{if(t.router){let s=g(t.router);t.parentPostmate.emit("pushRoutes",JSON.stringify(s,w()))}else t.parentPostmate.emit("pushRoutes")},isRouteExists(s){t.router?t.parentPostmate.emit("routeExists",M(t.router,s)):t.parentPostmate.emit("routeExists",!1)},routeUpdate(s){try{const r=JSON.parse(s);if(t.customRouteChange){t.customRouteChange(r),t.parentPostmate.emit("route_update_result",!0),console.log("----------------- 【ChildPastMate】路由更新完成 -----------------");return}t.router?(t.router.replace(r.fullPath),t.parentPostmate.emit("route_update_result",!0),console.log("----------------- 【ChildPastMate】路由更新完成 -----------------")):(t.parentPostmate.emit("route_update_result",!1),console.warn("【ChildPastMate】未提供router实例,无法进行路由更新"))}catch(r){console.error("【ChildPastMate】路由更新失败:",r),t.parentPostmate.emit("route_update_result",!1)}}}).then(s=>{this.stateOver=!0,t.parentPostmate=s,t.getData(),e.success({status:200,message:"success",data:{ChildPostmate:s}}),t.parentPostmate.emit("route_update_support",!!t.router),t.router&&t.parentPostmate.emit("pushRoutes",JSON.stringify(g(t.router),w()))}).catch(s=>{this.stateOver=!0,e.error({status:500,data:null,message:s})})}getData(e){if(!this.parentPostmate){e({status:500,message:"父页面未连接",data:null});return}e?(this.isGetData=!0,this.getDataCllBack=e):(this.isGetData=!1,this.getDataCllBack=null),this.parentPostmate.emit("requestBaseData")}setRouter(e,t){this.router=e,t&&(this.customRouteChange=t)}sendOtherRequest(e){this.parentPostmate&&this.parentPostmate.emit("otherRequest",e)}}class L{constructor(e,t,s="",r){this.postmateParent=null,this.dataInfo={loginInfo:{},token:"",isHideHeader:!0},this.iframeEle=null,this.currentUrl="",this.currentIframe=null,this.loadFunction=null,this.handleOtherRequest=null,this.childSupportsRouteUpdate=!0,this.childRoutes=[],this.eventBus={getRoutes:null,route_update_result:null},this.dataInfo=e||this.dataInfo,this.iframeEle=t,this.setIframeUrl(s),r&&(this.handleOtherRequest=r)}parseUrl(e){const t=document.createElement("a");t.href=e;const s=t.protocol.length>4?t.protocol:window.location.protocol,r=t.hostname,a=t.port||(s==="https:"?"443":s==="http:"?"80":""),o=t.pathname.startsWith("/")?t.pathname:`/${t.pathname}`,n=t.search,u=t.hash.slice(2,t.hash.length),d=t.origin||`${s}//${r}${a?`:${a}`:""}`,p=`${o}${u}`;return{protocol:s,host:r,port:a,pathname:o,search:n,hash:u,origin:d,fullPath:p}}compareUrlBase(e,t){const s=e.endsWith("/"),r=t.endsWith("/");return s&&r||!s&&!r||(s&&(t+="/"),r&&(e+="/")),e===t}compareUrlPath(e,t){if(!e||!t)return!1;const s=this.parseUrl(e),r=this.parseUrl(t);return s.pathname===r.pathname}compareUrlFull(e,t){if(!e||!t)return!1;const s=this.parseUrl(e),r=this.parseUrl(t);return s.fullPath===r.fullPath}clear(){this.postmateParent&&(this.postmateParent.destroy(),this.postmateParent=null),this.eventBus.getRoutes=null,this.eventBus.route_update_result=null,this.childRoutes=[],this.childSupportsRouteUpdate=!1,this.currentIframe&&this.currentIframe.parentNode&&this.currentIframe.parentNode.removeChild(this.currentIframe),this.currentIframe=null}async init(e=null){if(this.clear(),this.childSupportsRouteUpdate=!1,!this.iframeEle||!this.currentUrl){this.destroy();return}const t=typeof this.iframeEle=="function"?this.iframeEle():this.iframeEle;if(!t){console.warn("【ParentPostmate】无法获取 iframe 容器");return}const s=new h({container:t,url:this.currentUrl,name:"",model:""});this.currentIframe=t.querySelector("iframe"),this.currentIframe.setAttribute("frameborder","0"),this.currentIframe.setAttribute("allow","fullscreen"),this.currentIframe.addEventListener("load",()=>{this.loadFunction&&this.loadFunction()}),s.then(r=>{this.postmateParent=r,r.on("requestBaseData",()=>{this.sendData()}),r.on("pushRoutes",a=>{a?this.childRoutes=JSON.parse(a):this.childRoutes=[],this.eventBus.getRoutes&&this.eventBus.getRoutes()}),r.on("routeExists",a=>{}),r.on("route_update_support",a=>{this.childSupportsRouteUpdate=a}),r.on("route_update_result",a=>{this.eventBus.route_update_result&&this.eventBus.route_update_result(a)}),r.on("otherRequest",a=>{this.handleOtherRequest&&this.handleOtherRequest(a)}),typeof e=="function"&&e()}).catch(r=>{console.error("【ParentPostmate】Postmate 连接失败:",r)})}setLoadFunction(e){this.loadFunction=e}setIframeUrl(e,t=""){var r;if(e===this.currentUrl)return;if(t&&!t.startsWith("/")&&(t="/"+t),t&&t.endsWith("/")&&(t=t.slice(0,-1)),!e){this.currentUrl="",this.destroy(),console.error("【ParentPostmate】无加载地址,无法初始化");return}if(!this.postmateParent||!this.currentUrl){this.currentUrl=e,this.iframeEle?this.init():console.error("【ParentPostmate】无 iframe 容器,无法初始化");return}if(!this.childSupportsRouteUpdate||!((r=this.childRoutes)!=null&&r.length)||!$(this.currentUrl,e)){this.currentUrl=e,this.init();return}let s=!1;this.eventBus.getRoutes=()=>{s=!0,this.handleSimilarUrl(e,t)},this.postmateParent.call("getRoutes"),setTimeout(()=>{s||this.handleSimilarUrl(e,t)},1e3)}handleSimilarUrl(e,t){let s=e.split("?").length>1,r="";if(s&&(r="?"+e.split("?")[1]),t&&m(this.childRoutes,t)){this.sendRouteUpdate({fullPath:t+r}),this.currentUrl=e;return}const a=k(this.childRoutes,this.currentUrl);let o=new URL(e),n="";if(o.hash&&o.hash.indexOf("#/")>-1?n=o.hash.split("#")[1]:n=o.pathname+r,console.log(this.childRoutes,n.replace(a,"")),this.currentUrl.split(a)[0]===e.split(a)[0]&&m(this.childRoutes,n.replace(a,""))){this.sendRouteUpdate({fullPath:n.replace(a,"")}),console.log("推送地址:",e),console.log("推送路由:",n.replace(a,"")),console.log("当前地址:",this.currentUrl),this.currentUrl=e;return}this.currentUrl=e,this.init()}sendRouteUpdate(e){try{let t=!1;this.eventBus.route_update_result=s=>{t=s,this.loadFunction&&this.loadFunction()},this.postmateParent.call("routeUpdate",JSON.stringify(e)),console.log("---------------------- 【ParentPostmate】推送路由更新 ----------------------"),setTimeout(()=>{t||(console.warn("【ParentPostmate】推送路由更新失败,将重新初始化iframe"),this.childSupportsRouteUpdate=!1,this.init())},1e3)}catch(t){console.warn("【ParentPostmate】发送路由更新消息失败,将重新初始化iframe:",t),this.childSupportsRouteUpdate=!1,this.init()}}sendData(){this.postmateParent&&this.postmateParent.call("baseData",JSON.stringify(this.dataInfo))}destroy(){this.clear()}}c.ChildPostmate=B,c.ParentPostmate=L,Object.defineProperty(c,Symbol.toStringTag,{value:"Module"})});
|
|
2
2
|
//# sourceMappingURL=index.umd.js.map
|
package/lib/index.umd.js.gz
CHANGED
|
Binary file
|
package/lib/index.umd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.umd.js","sources":["../packages/postMeta/postMeta.js","../packages/postMeta/tools.ts","../packages/postMeta/ChildPostmate.ts","../packages/postMeta/ParentPostmate.ts"],"sourcesContent":["const MESSAGE_TYPE = \"application/x-postmate-v1+json\";\nlet uid = 0;\n\nconst allowedPostmateTypes = {\n handshake: 1,\n \"handshake-reply\": 1,\n call: 1,\n emit: 1,\n reply: 1,\n request: 1,\n};\n\n// 校验消息是否来自合法的来源\nfunction isValidMessage(event, allowedOrigin) {\n return (\n (typeof allowedOrigin !== \"string\" || event.origin === allowedOrigin) &&\n !!event.data &&\n (typeof event.data !== \"object\" || \"postmate\" in event.data) &&\n event.data.type === MESSAGE_TYPE &&\n !!allowedPostmateTypes[event.data.postmate]\n );\n}\n\n// ----------------- ParentAPI -----------------\nclass ParentAPI {\n constructor(config) {\n this.parent = config.parent;\n this.frame = config.frame;\n this.child = config.child;\n this.childOrigin = config.childOrigin;\n this.events = {};\n\n this.listener = (event) => {\n if (!isValidMessage(event, this.childOrigin)) return;\n const { value = {} } = event.data;\n const { name, data } = value;\n if (event.data.postmate === \"emit\" && name in this.events) {\n this.events[name].call(this, data);\n }\n };\n\n this.parent.addEventListener(\"message\", this.listener, false);\n }\n\n get(property) {\n return new Postmate.Promise((resolve) => {\n const id = ++uid;\n const handler = (event) => {\n if (event.data.uid === id && event.data.postmate === \"reply\") {\n this.parent.removeEventListener(\"message\", handler, false);\n resolve(event.data.value);\n }\n };\n this.parent.addEventListener(\"message\", handler, false);\n this.child.postMessage(\n {\n postmate: \"request\",\n type: MESSAGE_TYPE,\n property,\n uid: id,\n },\n this.childOrigin\n );\n });\n }\n\n call(method, data) {\n this.child.postMessage(\n {\n postmate: \"call\",\n type: MESSAGE_TYPE,\n property: method,\n data,\n },\n this.childOrigin\n );\n }\n\n on(event, callback) {\n this.events[event] = callback;\n }\n\n destroy() {\n window.removeEventListener(\"message\", this.listener, false);\n this.frame.parentNode.removeChild(this.frame);\n }\n}\n\n// ----------------- ChildAPI -----------------\nclass ChildAPI {\n constructor(config) {\n this.model = config.model;\n this.parent = config.parent;\n this.parentOrigin = config.parentOrigin;\n this.child = config.child;\n\n this.child.addEventListener(\"message\", (event) => {\n if (!isValidMessage(event, this.parentOrigin)) return;\n\n const { postmate, property, uid, data } = event.data;\n const value = this.model[property];\n\n if (postmate !== \"call\") {\n const result = typeof value === \"function\" ? value() : value;\n Postmate.Promise.resolve(result).then((res) => {\n event.source.postMessage(\n {\n property,\n postmate: \"reply\",\n type: MESSAGE_TYPE,\n uid,\n value: res,\n },\n event.origin\n );\n });\n } else if (property in this.model && typeof value === \"function\") {\n value(data);\n }\n });\n }\n\n emit(eventName, data) {\n this.parent.postMessage(\n {\n postmate: \"emit\",\n type: MESSAGE_TYPE,\n value: { name: eventName, data },\n },\n this.parentOrigin\n );\n }\n}\n\n// ----------------- Postmate -----------------\nclass Postmate {\n constructor({ container = document.body, model, url, name, classListArray = [] }) {\n this.parent = window;\n this.frame = document.createElement(\"iframe\");\n this.frame.name = name || \"\";\n this.frame.classList.add(...classListArray);\n container.appendChild(this.frame);\n\n this.child = this.frame.contentWindow;\n this.model = model || {};\n\n return this.sendHandshake(url);\n }\n\n sendHandshake(url) {\n const origin = (() => {\n const link = document.createElement(\"a\");\n link.href = url;\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n const host = link.host.length ? (link.port === \"80\" || link.port === \"443\" ? link.hostname : link.host) : window.location.host;\n return link.origin || `${protocol}//${host}`;\n })();\n\n let attemptCount = 0;\n let interval;\n\n return new Postmate.Promise((resolve, reject) => {\n const listener = (event) => {\n if (!isValidMessage(event, origin)) return false;\n if (event.data.postmate === \"handshake-reply\") {\n clearInterval(interval);\n this.parent.removeEventListener(\"message\", listener, false);\n this.childOrigin = event.origin;\n resolve(new ParentAPI(this));\n } else {\n reject(\"Failed handshake\");\n }\n };\n\n this.parent.addEventListener(\"message\", listener, false);\n\n const send = () => {\n attemptCount++;\n this.child.postMessage(\n {\n postmate: \"handshake\",\n type: MESSAGE_TYPE,\n model: this.model,\n },\n origin\n );\n if (attemptCount === 5) clearInterval(interval);\n };\n\n const init = () => {\n send();\n interval = setInterval(send, 500);\n };\n\n this.frame.onload = init;\n this.frame.attachEvent && this.frame.attachEvent(\"onload\", init);\n this.frame.src = url;\n });\n }\n}\n\n// ----------------- Model -----------------\nclass Model {\n constructor(model) {\n this.child = window;\n this.model = model;\n this.parent = window.parent;\n\n return this.sendHandshakeReply();\n }\n\n sendHandshakeReply() {\n return new Postmate.Promise((resolve, reject) => {\n this.child.addEventListener(\"message\", (event) => {\n if (event.data.postmate) {\n if (event.data.postmate !== \"handshake\") return reject(\"Handshake Reply Failed\");\n\n this.child.removeEventListener(\"message\", this, false);\n event.source.postMessage(\n {\n postmate: \"handshake-reply\",\n type: MESSAGE_TYPE,\n },\n event.origin\n );\n\n this.parentOrigin = event.origin;\n const parentModel = event.data.model;\n if (parentModel) {\n Object.keys(parentModel).forEach((key) => {\n this.model[key] = parentModel[key];\n });\n }\n resolve(new ChildAPI(this));\n }\n }, false);\n });\n }\n}\n\n// Attach defaults\nPostmate.debug = false;\nPostmate.Promise = (() => {\n try {\n return typeof window !== \"undefined\" ? window.Promise : Promise;\n } catch {\n return Promise;\n }\n})();\nPostmate.Model = Model;\n\nexport default Postmate;\nexport { Model };\n","/**\n * 检查路径是否存在于路由配置中(递归检查所有层级)\n * @param routes 路由配置数组\n * @param path 需要检查的路径\n * @returns 是否存在\n */\nexport function checkPathInRoutes(routes: any[], path: string): boolean {\n\tfor (const route of routes) {\n\t\t// 检查当前路由\n\t\tif (route.path === path) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// 递归检查子路由\n\t\tif (route.children && Array.isArray(route.children) && route.children.length > 0) {\n\t\t\tif (checkPathInRoutes(route.children, path)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n}\n\n/**\n * 判断路径是否存在于vue-router对象中(兼容Vue2和Vue3)\n * @param router vue-router实例\n * @param path 需要检查的页面路径\n * @returns 路径是否存在\n */\nexport function isRouteExists(router: any, path: string): boolean {\n\t// 移除路径中的查询参数\n\tif (path.includes('?')) {\n\t\tpath = path.split('?')[0];\n\t}\n\tconst routes = getRouterPaths(router);\n\tif (!routes || routes.length === 0) return false;\n\treturn checkPathInRoutes(routes, path);\n}\n\n// 净化单个路由配置,只保留安全字段\nfunction purifyRoute(route) {\n\t// 只提取需要的基础字段,根据你的需求调整\n\tconst safeFields = {\n\t\tpath: route.path,\n\t\tname: route.name,\n\t\tmeta: route.meta || {}, // 确保meta是普通对象\n\t\tredirect: route.redirect,\n\t\t// 剔除 component、beforeEnter 等可能包含函数/对象引用的字段\n\t\t// 如果需要children,递归净化\n\t\tchildren: route.children ? route.children.map((child) => purifyRoute(child)) : [],\n\t};\n\n\t// 进一步净化meta(如果meta中可能有复杂对象)\n\tsafeFields.meta = JSON.parse(JSON.stringify(safeFields.meta));\n\n\treturn safeFields;\n}\n\n/**\n * 获取路由路径\n *\n */\nexport function getRouterPaths(router: any): any[] {\n\tlet routes: any[] = [];\n\t// 区分Vue Router 3.x (Vue2) 和 4.x (Vue3)\n\tif (typeof router.getRoutes === 'function') {\n\t\t// Vue Router 4.x (Vue3)\n\t\troutes = router.getRoutes();\n\t} else if (router.options && Array.isArray(router.options.routes)) {\n\t\t// Vue Router 3.x (Vue2)\n\t\troutes = router.options.routes;\n\t}\n\treturn routes.map((route) => purifyRoute(route)) || [];\n}\n\n/**\n * 比较两个URL的协议、IP(或域名)和端口是否完全相同\n * @param url1 第一个URL字符串\n * @param url2 第二个URL字符串\n * @returns 如果协议、IP(或域名)和端口都相同则返回true,否则返回false;解析失败时返回false\n */\nexport function areUrlsSameProtocolIpPort(url1: string, url2: string): boolean {\n\ttry {\n\t\t// 解析两个URL\n\t\tconst parsedUrl1 = new URL(url1);\n\t\tconst parsedUrl2 = new URL(url2);\n\n\t\t// 比较协议(不区分大小写,但通常URL协议是小写的)\n\t\tconst sameProtocol = parsedUrl1.protocol.toLowerCase() === parsedUrl2.protocol.toLowerCase();\n\n\t\t// 比较主机(IP或域名)\n\t\tconst sameHost = parsedUrl1.hostname === parsedUrl2.hostname;\n\n\t\t// 比较端口(如果未指定端口,会使用协议默认端口)\n\t\tconst samePort = parsedUrl1.port === parsedUrl2.port;\n\n\t\t// 只有所有部分都相同时才返回true\n\t\treturn sameProtocol && sameHost && samePort;\n\t} catch (error) {\n\t\t// 如果URL解析失败,返回false\n\t\tconsole.error('URL解析错误:', error);\n\t\treturn false;\n\t}\n}\n\nexport const getCircularReplacer = () => {\n\tconst seen = new WeakSet();\n\treturn (key, value) => {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tif (seen.has(value)) {\n\t\t\t\t// 遇到循环引用时,返回一个标识或忽略\n\t\t\t\treturn '[Circular Reference]';\n\t\t\t}\n\t\t\tseen.add(value);\n\t\t}\n\t\treturn value;\n\t};\n};\n","import Postmate from './postMeta';\nimport { getCircularReplacer, getRouterPaths, isRouteExists } from './tools';\n\ninterface EventObj {\n\terror: (error: any) => void;\n\tsuccess: (success: any) => void;\n\treceive: (receive: any) => void;\n}\n\n// 路由更新接口\ninterface RouteUpdateInfo {\n\tfullPath: string;\n}\n\nexport default class ChildPostmate {\n\tchildPostmate: any = null;\n\tparentPostmate: any = null;\n\n\tisGetData: boolean = false;\n\tgetDataCllBack: Function | null = null;\n\tstateOver: boolean = false;\n\n\t// Vue Router实例\n\trouter: any = null;\n\t// 路由更新回调函数\n\trouteUpdateCallback: ((routeInfo: RouteUpdateInfo) => void) | undefined = undefined;\n\n\tconstructor(eventObj: EventObj, router: any, routeUpdateCallback?: (routeInfo: RouteUpdateInfo) => void) {\n\t\t// 保存router实例\n\t\tthis.router = router;\n\t\t// 保存路由更新回调函数\n\t\tthis.routeUpdateCallback = routeUpdateCallback;\n\n\t\tif (window.top !== window.self) {\n\t\t\tthis.init(eventObj);\n\t\t\tsetTimeout(() => {\n\t\t\t\tif (this.stateOver) return;\n\t\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t\t}, 500);\n\t\t} else {\n\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t}\n\t}\n\n\tinit(eventObj: EventObj) {\n\t\tconst that = this;\n\t\t// 创建 Postmate Model(作为子)\n\t\tthis.childPostmate = new Postmate.Model({\n\t\t\t// 定义子页面可以暴露给父页面的方法\n\t\t\tbaseData(data: any) {\n\t\t\t\tdata = JSON.parse(data);\n\t\t\t\tif (that.isGetData) {\n\t\t\t\t\tthat.getDataCllBack &&\n\t\t\t\t\t\tthat.getDataCllBack({\n\t\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\t\tdata: data,\n\t\t\t\t\t\t});\n\t\t\t\t} else\n\t\t\t\t\teventObj.receive({\n\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\tdata: data,\n\t\t\t\t\t});\n\t\t\t\tthat.isGetData = false;\n\t\t\t},\n\n\t\t\t// 提供当前系统的路由\n\t\t\tgetRoutes: () => {\n\t\t\t\t// 有路由\n\t\t\t\tif (that.router) {\n\t\t\t\t\tlet arr = getRouterPaths(that.router);\n\t\t\t\t\tthat.parentPostmate.emit('pushRoutes', JSON.stringify(arr, getCircularReplacer()));\n\t\t\t\t}\n\t\t\t\t// 无路由\n\t\t\t\telse that.parentPostmate.emit('pushRoutes');\n\t\t\t},\n\n\t\t\t// 检查路由是否存在\n\t\t\tisRouteExists(routePath: string) {\n\t\t\t\tif (that.router) that.parentPostmate.emit('routeExists', isRouteExists(that.router, routePath));\n\t\t\t\telse that.parentPostmate.emit('routeExists', false);\n\t\t\t},\n\n\t\t\t// 处理路由更新\n\t\t\trouteUpdate(routeInfoStr: string) {\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\ttry {\n\t\t\t\t\tconst routeInfo: RouteUpdateInfo = JSON.parse(routeInfoStr);\n\n\t\t\t\t\t// 如果提供了自定义的路由更新回调函数,则调用它\n\t\t\t\t\tif (that.routeUpdateCallback) {\n\t\t\t\t\t\tthat.routeUpdateCallback(routeInfo);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t// 如果提供了router实例,则使用router进行路由更新\n\t\t\t\t\tif (that.router) {\n\t\t\t\t\t\tthat.router.replace(routeInfo.fullPath);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t\t\tconsole.warn('【ChildPastMate】未提供router实例,无法进行路由更新');\n\t\t\t\t\t}\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsole.error('【ChildPastMate】路由更新失败:', error);\n\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t}\n\t\t\t},\n\t\t})\n\t\t\t.then((parent: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\tthat.parentPostmate = parent;\n\t\t\t\tthat.getData();\n\t\t\t\t// 与父页面链接建立成功\n\t\t\t\teventObj.success({\n\t\t\t\t\tstatus: 200,\n\t\t\t\t\tmessage: 'success',\n\t\t\t\t\tdata: {\n\t\t\t\t\t\tChildPostmate: parent,\n\t\t\t\t\t},\n\t\t\t\t});\n\t\t\t\t// 告诉父系统支持路由更新\n\t\t\t\tthat.parentPostmate.emit('route_update_support', that.router ? true : false);\n\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\tthat.router && that.parentPostmate.emit('pushRoutes', JSON.stringify(getRouterPaths(that.router), getCircularReplacer()));\n\t\t\t})\n\t\t\t.catch((err: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\teventObj.error({ status: 500, data: null, message: err });\n\t\t\t});\n\t}\n\n\t// 获取数据\n\tgetData(callback?: any) {\n\t\tif (!this.parentPostmate) {\n\t\t\tcallback({\n\t\t\t\tstatus: 500,\n\t\t\t\tmessage: '父页面未连接',\n\t\t\t\tdata: null,\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\n\t\tif (callback) {\n\t\t\tthis.isGetData = true;\n\t\t\tthis.getDataCllBack = callback;\n\t\t} else {\n\t\t\tthis.isGetData = false;\n\t\t\tthis.getDataCllBack = null;\n\t\t}\n\t\t// 向父页面获取数据\n\t\tthis.parentPostmate.emit('requestBaseData');\n\t}\n\n\t/**\n\t * 设置路由实例和路由更新回调\n\t * @param router Vue Router实例\n\t * @param routeUpdateCallback 自定义路由更新回调函数\n\t */\n\tsetRouter(router: any, routeUpdateCallback?: (routeInfo: RouteUpdateInfo) => void) {\n\t\tthis.router = router;\n\t\tif (routeUpdateCallback) {\n\t\t\tthis.routeUpdateCallback = routeUpdateCallback;\n\t\t}\n\t}\n\n\t/**\n\t * 向父页面发送其他请求\n\t * @param params 请求参数\n\t */\n\tsendOtherRequest(params: any) {\n\t\tif (!this.parentPostmate) return;\n\t\tthis.parentPostmate.emit('otherRequest', params);\n\t}\n}\n","import Postmate from './postMeta';\nimport { areUrlsSameProtocolIpPort, checkPathInRoutes } from './tools';\n\ninterface DataInfo {\n loginInfo: { [x: string]: any };\n token: string;\n isHideHeader: boolean;\n}\n\n// URL解析结果接口\ninterface ParsedUrl {\n protocol: string;\n host: string;\n port: string;\n pathname: string;\n search: string;\n hash: string;\n origin: string;\n fullPath: string;\n}\n\nexport default class ParentPostmate {\n /** 连接到的子 postmate 实例 */\n postmateParent: any = null;\n /** 通讯数据 */\n dataInfo: DataInfo = {\n loginInfo: {},\n token: '',\n isHideHeader: true,\n };\n /** iframe Dom 容器 */\n iframeEle: any = null;\n /** 当前 iframe url */\n currentUrl: string = '';\n /** 存储当前的 iframe 元素 */\n currentIframe: any = null;\n /** iframe 加载完成执行函数 */\n loadFunction: (() => void) | null = null;\n /** 处理子类的其他请求方法 */\n handleOtherRequest: ((params: any) => void) | null = null;\n /** 子页面是否支持路由更新 */\n childSupportsRouteUpdate: boolean = true;\n /** 子系统的路由列表 */\n childRoutes: any[] = [];\n\n eventBus: any = {\n getRoutes: null,\n route_update_resultL: null,\n };\n\n constructor(\n dataInfo: DataInfo,\n iframeEle: HTMLElement | (() => HTMLElement),\n iframeUrl: string = '',\n handleOtherRequest?: (params: any) => void,\n ) {\n this.dataInfo = dataInfo || this.dataInfo;\n this.iframeEle = iframeEle;\n this.setIframeUrl(iframeUrl);\n handleOtherRequest && (this.handleOtherRequest = handleOtherRequest);\n }\n\n /** 解析URL */\n parseUrl(url: string): ParsedUrl {\n const link = document.createElement('a');\n link.href = url;\n\n // 获取协议\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n\n // 获取主机和端口\n const host = link.hostname;\n const port =\n link.port || (protocol === 'https:' ? '443' : protocol === 'http:' ? '80' : '');\n\n // 获取路径、查询参数和哈希\n const pathname = link.pathname.startsWith('/') ? link.pathname : `/${link.pathname}`;\n const search = link.search;\n const hash = link.hash.slice(2, link.hash.length);\n\n // 构建origin\n const origin = link.origin || `${protocol}//${host}${port ? `:${port}` : ''}`;\n\n // 构建完整路径(不包含origin)\n const fullPath = `${pathname}${hash}`;\n\n return {\n protocol,\n host,\n port,\n pathname,\n search,\n hash,\n origin,\n fullPath,\n };\n }\n\n /** 比较两个URL是否相同*/\n compareUrlBase(url1: string, url2: string): boolean {\n const url1End = url1.endsWith('/');\n const url2End = url2.endsWith('/');\n if ((url1End && url2End) || (!url1End && !url2End)) {\n return url1 === url2;\n } else {\n if (url1End) url2 += '/';\n if (url2End) url1 += '/';\n return url1 === url2;\n }\n }\n\n /** 比较两个URL的路径是否相同(不包含查询参数和哈希) */\n compareUrlPath(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.pathname === parsed2.pathname;\n }\n\n /** 比较两个URL是否完全相同(包括查询参数和哈希) */\n compareUrlFull(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.fullPath === parsed2.fullPath;\n }\n\n /** 清除当前的 iframe 和 postmate 实例 */\n clear() {\n // 销毁 postmate 实例\n if (this.postmateParent) {\n this.postmateParent.destroy();\n this.postmateParent = null;\n }\n\n this.eventBus.getRoutes = null;\n this.eventBus.route_update_result = null;\n this.childRoutes = [];\n this.childSupportsRouteUpdate = false;\n\n // 移除 iframe\n if (this.currentIframe && this.currentIframe.parentNode) {\n this.currentIframe.parentNode.removeChild(this.currentIframe);\n }\n this.currentIframe = null;\n }\n\n /** 初始化 */\n async init(callback: any = null) {\n // 清除之前的实例和 iframe\n this.clear();\n\n // 重置子页面路由更新支持标记\n this.childSupportsRouteUpdate = false;\n\n // 如果没有容器,或集成链接\n if (!this.iframeEle || !this.currentUrl) {\n this.destroy();\n return;\n }\n\n // 获取 iframe 容器\n const container: any =\n typeof this.iframeEle === 'function' ? this.iframeEle() : this.iframeEle;\n if (!container) {\n console.warn('【ParentPostmate】无法获取 iframe 容器');\n return;\n }\n\n // 创建 Postmate 实例(作为父)\n const handshake: any = new Postmate({\n container,\n url: this.currentUrl,\n name: '',\n model: '',\n });\n\n // 存储当前创建的 iframe\n this.currentIframe = container.querySelector('iframe');\n this.currentIframe.setAttribute('frameborder', '0');\n this.currentIframe.setAttribute('allow', 'fullscreen');\n this.currentIframe.addEventListener('load', () => {\n this.loadFunction && this.loadFunction();\n });\n\n handshake\n .then((parent: any) => {\n this.postmateParent = parent;\n\n // 监听子页面发来的获取数据请求\n parent.on('requestBaseData', () => {\n // 发送相关数据\n this.sendData();\n });\n\n // 监听子页面发来的路由配置数据\n parent.on('pushRoutes', (routes: string) => {\n if (routes) this.childRoutes = JSON.parse(routes);\n else this.childRoutes = [];\n this.eventBus.getRoutes && this.eventBus.getRoutes();\n });\n\n // 监听子页面的路由效验结果\n parent.on('routeExists', (flag: boolean) => {});\n\n // 监听子页面的动态路由变更支持\n parent.on('route_update_support', (flag: boolean) => {\n this.childSupportsRouteUpdate = flag;\n });\n\n // 监听子页面的路由变更结果\n parent.on('route_update_result', (flag: boolean) => {\n this.eventBus.route_update_result && this.eventBus.route_update_result(flag);\n });\n\n // 监听子页面发来的其他请求\n parent.on('otherRequest', (params: any) => {\n this.handleOtherRequest && this.handleOtherRequest(params);\n });\n\n if (typeof callback === 'function') callback();\n })\n .catch((error: any) => {\n console.error('【ParentPostmate】Postmate 连接失败:', error);\n });\n }\n\n /** 设置load执行事件 */\n setLoadFunction(loadFunction: () => void) {\n this.loadFunction = loadFunction;\n }\n\n /** 设置 iframe url */\n setIframeUrl(iframeUrl: string, routerPath: string = '') {\n // 如果完全一样:不操作\n if (iframeUrl === this.currentUrl) return;\n\n // 如果传入了路由,则对路径进行规范处理\n if (routerPath && !routerPath.startsWith('/')) {\n routerPath = '/' + routerPath;\n }\n\n if (routerPath && routerPath.endsWith('/')) {\n routerPath = routerPath.slice(0, -1);\n }\n\n // 1、传入的地址为空:销毁当前实例\n if (!iframeUrl) {\n this.currentUrl = '';\n this.destroy();\n console.error('【ParentPostmate】无加载地址,无法初始化');\n return;\n }\n\n // 2、如果当前无连接:直接设置并初始化\n if (!this.postmateParent || !this.currentUrl) {\n this.currentUrl = iframeUrl;\n if (this.iframeEle) this.init();\n else console.error('【ParentPostmate】无 iframe 容器,无法初始化');\n return;\n }\n\n // 3、如果当前系统不支持路由更新 或 新旧系统协议、ip、端口不同则重新初始化: 重新初始化\n if (\n !this.childSupportsRouteUpdate ||\n !this.childRoutes?.length ||\n !areUrlsSameProtocolIpPort(this.currentUrl, iframeUrl)\n ) {\n this.currentUrl = iframeUrl;\n this.init();\n return;\n }\n\n /**\n * 因新旧地址的基础地址完全相同,且已加载系统支持路由更新\n * 下面处理新旧地址的url,研判操作方式\n **/\n // 更新路由列表\n let flag = false;\n this.eventBus.getRoutes = () => {\n flag = true;\n this.handleSimilarUrl(iframeUrl, routerPath);\n };\n this.postmateParent.call('getRoutes');\n\n setTimeout(() => {\n if (flag) return;\n this.handleSimilarUrl(iframeUrl, routerPath);\n }, 1000);\n }\n\n // 处理相似地址\n handleSimilarUrl(iframeUrl: string, routerPath?: string) {\n this.currentUrl = iframeUrl;\n\n // 1 如果传入了routerPath,将该值与子系统匹配,判断是否可以直接跳转\n if (routerPath && checkPathInRoutes(this.childRoutes, routerPath)) {\n // 触发更新路由\n this.sendRouteUpdate({\n fullPath: routerPath,\n });\n return;\n }\n\n // 2 通过已加载子系统的路由列表匹配新链接的尾部路径,如果匹配到,则触发路由更新\n let isEnd = false;\n let noQueryUrl = iframeUrl.split('?')[0];\n this.childRoutes.forEach((v) => {\n if (noQueryUrl.endsWith(v.path)) {\n // 触发更新路由\n this.sendRouteUpdate({\n fullPath: v.path,\n });\n isEnd = true;\n return;\n }\n });\n if (isEnd) return;\n\n // 3 如果以上两种情况都不满足,则重新初始化\n this.init();\n }\n\n /** 向子页面发送路由更新消息 */\n sendRouteUpdate(parsedUrl: any) {\n try {\n let flag = false;\n this.eventBus.route_update_result = (state: boolean) => {\n flag = state;\n this.loadFunction && this.loadFunction();\n };\n this.postmateParent.call('routeUpdate', JSON.stringify(parsedUrl));\n console.log(\n '---------------------- 【ParentPostmate】推送路由更新 ----------------------',\n );\n setTimeout(() => {\n if (flag) return;\n console.warn('【ParentPostmate】推送路由更新失败,将重新初始化iframe');\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }, 1000);\n } catch (error) {\n console.warn('【ParentPostmate】发送路由更新消息失败,将重新初始化iframe:', error);\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }\n }\n\n /** 向子页面发送消息 */\n sendData() {\n if (!this.postmateParent) return;\n this.postmateParent.call('baseData', JSON.stringify(this.dataInfo));\n }\n\n /** 销毁实例 */\n destroy() {\n this.clear();\n }\n}\n"],"names":["MESSAGE_TYPE","uid","allowedPostmateTypes","isValidMessage","event","allowedOrigin","ParentAPI","config","value","name","data","property","Postmate","resolve","id","handler","method","callback","ChildAPI","postmate","result","res","eventName","container","model","url","classListArray","origin","link","protocol","host","attemptCount","interval","reject","listener","send","init","Model","parentModel","key","checkPathInRoutes","routes","path","route","isRouteExists","router","getRouterPaths","purifyRoute","safeFields","child","areUrlsSameProtocolIpPort","url1","url2","parsedUrl1","parsedUrl2","sameProtocol","sameHost","samePort","error","getCircularReplacer","seen","ChildPostmate","eventObj","routeUpdateCallback","that","arr","routePath","routeInfoStr","routeInfo","parent","err","params","ParentPostmate","dataInfo","iframeEle","iframeUrl","handleOtherRequest","port","pathname","search","hash","fullPath","url1End","url2End","parsed1","parsed2","handshake","flag","loadFunction","routerPath","_a","isEnd","noQueryUrl","v","parsedUrl","state"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.umd.js","sources":["../packages/postMeta/postMeta.js","../packages/postMeta/RouteMatching.ts","../packages/postMeta/tools.ts","../packages/postMeta/ChildPostmate.ts","../packages/postMeta/ParentPostmate.ts"],"sourcesContent":["const MESSAGE_TYPE = \"application/x-postmate-v1+json\";\nlet uid = 0;\n\nconst allowedPostmateTypes = {\n handshake: 1,\n \"handshake-reply\": 1,\n call: 1,\n emit: 1,\n reply: 1,\n request: 1,\n};\n\n// 校验消息是否来自合法的来源\nfunction isValidMessage(event, allowedOrigin) {\n return (\n (typeof allowedOrigin !== \"string\" || event.origin === allowedOrigin) &&\n !!event.data &&\n (typeof event.data !== \"object\" || \"postmate\" in event.data) &&\n event.data.type === MESSAGE_TYPE &&\n !!allowedPostmateTypes[event.data.postmate]\n );\n}\n\n// ----------------- ParentAPI -----------------\nclass ParentAPI {\n constructor(config) {\n this.parent = config.parent;\n this.frame = config.frame;\n this.child = config.child;\n this.childOrigin = config.childOrigin;\n this.events = {};\n\n this.listener = (event) => {\n if (!isValidMessage(event, this.childOrigin)) return;\n const { value = {} } = event.data;\n const { name, data } = value;\n if (event.data.postmate === \"emit\" && name in this.events) {\n this.events[name].call(this, data);\n }\n };\n\n this.parent.addEventListener(\"message\", this.listener, false);\n }\n\n get(property) {\n return new Postmate.Promise((resolve) => {\n const id = ++uid;\n const handler = (event) => {\n if (event.data.uid === id && event.data.postmate === \"reply\") {\n this.parent.removeEventListener(\"message\", handler, false);\n resolve(event.data.value);\n }\n };\n this.parent.addEventListener(\"message\", handler, false);\n this.child.postMessage(\n {\n postmate: \"request\",\n type: MESSAGE_TYPE,\n property,\n uid: id,\n },\n this.childOrigin\n );\n });\n }\n\n call(method, data) {\n this.child.postMessage(\n {\n postmate: \"call\",\n type: MESSAGE_TYPE,\n property: method,\n data,\n },\n this.childOrigin\n );\n }\n\n on(event, callback) {\n this.events[event] = callback;\n }\n\n destroy() {\n window.removeEventListener(\"message\", this.listener, false);\n this.frame.parentNode.removeChild(this.frame);\n }\n}\n\n// ----------------- ChildAPI -----------------\nclass ChildAPI {\n constructor(config) {\n this.model = config.model;\n this.parent = config.parent;\n this.parentOrigin = config.parentOrigin;\n this.child = config.child;\n\n this.child.addEventListener(\"message\", (event) => {\n if (!isValidMessage(event, this.parentOrigin)) return;\n\n const { postmate, property, uid, data } = event.data;\n const value = this.model[property];\n\n if (postmate !== \"call\") {\n const result = typeof value === \"function\" ? value() : value;\n Postmate.Promise.resolve(result).then((res) => {\n event.source.postMessage(\n {\n property,\n postmate: \"reply\",\n type: MESSAGE_TYPE,\n uid,\n value: res,\n },\n event.origin\n );\n });\n } else if (property in this.model && typeof value === \"function\") {\n value(data);\n }\n });\n }\n\n emit(eventName, data) {\n this.parent.postMessage(\n {\n postmate: \"emit\",\n type: MESSAGE_TYPE,\n value: { name: eventName, data },\n },\n this.parentOrigin\n );\n }\n}\n\n// ----------------- Postmate -----------------\nclass Postmate {\n constructor({ container = document.body, model, url, name, classListArray = [] }) {\n this.parent = window;\n this.frame = document.createElement(\"iframe\");\n this.frame.name = name || \"\";\n this.frame.classList.add(...classListArray);\n container.appendChild(this.frame);\n\n this.child = this.frame.contentWindow;\n this.model = model || {};\n\n return this.sendHandshake(url);\n }\n\n sendHandshake(url) {\n const origin = (() => {\n const link = document.createElement(\"a\");\n link.href = url;\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n const host = link.host.length ? (link.port === \"80\" || link.port === \"443\" ? link.hostname : link.host) : window.location.host;\n return link.origin || `${protocol}//${host}`;\n })();\n\n let attemptCount = 0;\n let interval;\n\n return new Postmate.Promise((resolve, reject) => {\n const listener = (event) => {\n if (!isValidMessage(event, origin)) return false;\n if (event.data.postmate === \"handshake-reply\") {\n clearInterval(interval);\n this.parent.removeEventListener(\"message\", listener, false);\n this.childOrigin = event.origin;\n resolve(new ParentAPI(this));\n } else {\n reject(\"Failed handshake\");\n }\n };\n\n this.parent.addEventListener(\"message\", listener, false);\n\n const send = () => {\n attemptCount++;\n this.child.postMessage(\n {\n postmate: \"handshake\",\n type: MESSAGE_TYPE,\n model: this.model,\n },\n origin\n );\n if (attemptCount === 5) clearInterval(interval);\n };\n\n const init = () => {\n send();\n interval = setInterval(send, 500);\n };\n\n this.frame.onload = init;\n this.frame.attachEvent && this.frame.attachEvent(\"onload\", init);\n this.frame.src = url;\n });\n }\n}\n\n// ----------------- Model -----------------\nclass Model {\n constructor(model) {\n this.child = window;\n this.model = model;\n this.parent = window.parent;\n\n return this.sendHandshakeReply();\n }\n\n sendHandshakeReply() {\n return new Postmate.Promise((resolve, reject) => {\n this.child.addEventListener(\"message\", (event) => {\n if (event.data.postmate) {\n if (event.data.postmate !== \"handshake\") return reject(\"Handshake Reply Failed\");\n\n this.child.removeEventListener(\"message\", this, false);\n event.source.postMessage(\n {\n postmate: \"handshake-reply\",\n type: MESSAGE_TYPE,\n },\n event.origin\n );\n\n this.parentOrigin = event.origin;\n const parentModel = event.data.model;\n if (parentModel) {\n Object.keys(parentModel).forEach((key) => {\n this.model[key] = parentModel[key];\n });\n }\n resolve(new ChildAPI(this));\n }\n }, false);\n });\n }\n}\n\n// Attach defaults\nPostmate.debug = false;\nPostmate.Promise = (() => {\n try {\n return typeof window !== \"undefined\" ? window.Promise : Promise;\n } catch {\n return Promise;\n }\n})();\nPostmate.Model = Model;\n\nexport default Postmate;\nexport { Model };\n","import type { RouteRecordRaw } from 'vue-router';\r\n\r\n/**\r\n * 标准化基础路由(base):确保以 / 开头,不以 / 结尾(空字符串除外)\r\n */\r\nconst normalizeBase = (base: string): string => {\r\n if (!base || base === '/') return '';\r\n const trimmed = base.replace(/\\/$/, '');\r\n return trimmed.startsWith('/') ? trimmed : `/${trimmed}`;\r\n};\r\n\r\n/**\r\n * 从全量地址中提取「相对于base的路由路径」\r\n */\r\nconst extractRelativePath = (fullAddress: string, base = ''): string | null => {\r\n if (!fullAddress) return null;\r\n const normalizedBase = normalizeBase(base);\r\n let pathname = '';\r\n\r\n try {\r\n const url = new URL(fullAddress);\r\n pathname = url.pathname;\r\n } catch {\r\n pathname = fullAddress.split(/[?#]/)[0];\r\n }\r\n\r\n // 1. 去重斜杠 + 标准化路径(核心:避免//导致的匹配问题)\r\n const normalizedPathname = pathname.replace(/\\/+/g, '/').replace(/\\/$/, '') || '/';\r\n\r\n if (normalizedBase && !normalizedPathname.startsWith(normalizedBase)) {\r\n return null;\r\n }\r\n\r\n let relativePath = normalizedBase\r\n ? normalizedPathname.slice(normalizedBase.length)\r\n : normalizedPathname;\r\n\r\n // 确保相对路径以/开头,且无重复斜杠\r\n relativePath = relativePath.replace(/\\/+/g, '/');\r\n relativePath = relativePath.startsWith('/') ? relativePath : `/${relativePath}`;\r\n return relativePath === '' ? '/' : relativePath;\r\n};\r\n\r\n/**\r\n * 核心修复:路由路径转正则(解决重复斜杠+动态参数匹配)\r\n * 关键优化:复用路径中原有的/,不再额外生成/\r\n */\r\nconst convertRoutePathToRegex = (routePath: string): RegExp => {\r\n if (!routePath) return /^$/iu;\r\n\r\n // 步骤1:标准化路由路径(去重斜杠 + 去除末尾斜杠)\r\n const normalizedRoutePath =\r\n routePath\r\n .replace(/\\/+/g, '/') // 去重所有重复斜杠(// → /)\r\n .replace(/\\/$/, '') || '/';\r\n\r\n // 步骤2:先转义原始路径的正则特殊字符(仅转义非动态参数部分)\r\n let regexStr = normalizedRoutePath.replace(/([.?+^$[\\](){}|-])/g, '\\\\$1');\r\n\r\n // 步骤3:处理动态路由语法(核心:不复用原有/,不再额外加/)\r\n regexStr = regexStr\r\n // 1. 通配符 :pathMatch(.*)* → 匹配任意多级路径(复用原有/)\r\n .replace(/:pathMatch\\\\\\(\\.\\*\\\\\\)\\*/g, '.+')\r\n // 2. 带正则约束的参数(如 :id(\\\\d+) → 保留正则,不复用原有/)\r\n .replace(/:([a-zA-Z0-9_]+)\\\\\\(([^)]+)\\\\\\)/g, (_, __, regex) => regex.replace(/\\\\\\\\/g, '\\\\'))\r\n // 3. 可选动态参数(如 :id? → 匹配 空 或 非/字符,复用原有/)\r\n .replace(/:([a-zA-Z0-9_]+)\\?/g, '[^/]*')\r\n // 4. 普通动态参数(核心修复:仅匹配非/字符,不复用原有/)\r\n .replace(/:([a-zA-Z0-9_]+)/g, '[^/]+');\r\n\r\n // 步骤4:拼接完整正则(确保无重复斜杠)\r\n regexStr = regexStr.replace(/\\/+/g, '\\\\/'); // 转义/,且去重\r\n return new RegExp(`^${regexStr}$`, 'iu');\r\n};\r\n\r\n/**\r\n * 递归遍历路由(保留调试日志)\r\n */\r\nconst traverseRoutes = (\r\n routers: RouteRecordRaw[],\r\n targetRelativePath: string,\r\n parentPath = '',\r\n): boolean => {\r\n // 目标路径去重斜杠 + 标准化\r\n const normalizedTarget = targetRelativePath.replace(/\\/+/g, '/').replace(/\\/$/, '') || '/';\r\n\r\n for (const route of routers) {\r\n // 修复嵌套路由拼接逻辑(彻底避免重复斜杠)\r\n const processedParentPath = parentPath.replace(/\\/+/g, '/').replace(/\\/$/, '');\r\n const processedRoutePath = route.path.replace(/\\/+/g, '/').replace(/^\\//, '');\r\n const fullRoutePath = processedParentPath\r\n ? `${processedParentPath}/${processedRoutePath}`.replace(/\\/+/g, '/')\r\n : route.path.replace(/\\/+/g, '/');\r\n\r\n const routeRegex = convertRoutePathToRegex(fullRoutePath);\r\n const isMatched = routeRegex.test(normalizedTarget);\r\n\r\n if (isMatched) return true;\r\n\r\n if (route.children && route.children.length) {\r\n const childMatched = traverseRoutes(route.children, normalizedTarget, fullRoutePath);\r\n if (childMatched) return true;\r\n }\r\n }\r\n\r\n return false;\r\n};\r\n\r\n/**\r\n * 对外方法\r\n */\r\nexport const isRouteMatched = (\r\n routers: RouteRecordRaw[],\r\n fullAddress: string,\r\n base = '',\r\n): boolean => {\r\n if (!routers || !routers.length || !fullAddress) return false;\r\n const relativePath = extractRelativePath(fullAddress, base);\r\n if (!relativePath) return false;\r\n return traverseRoutes(routers, relativePath);\r\n};\r\n","import { isRouteMatched } from './RouteMatching';\n\n/**\n * 检查路径是否存在于路由配置中(递归检查所有层级)\n * @param routes 路由配置数组\n * @param path 需要检查的路径\n * @returns 是否存在\n */\nexport function checkPathInRoutes(routes: any[], path: string): boolean {\n\tfor (const route of routes) {\n\t\t// 检查当前路由\n\t\tif (route.path === path) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// 递归检查子路由\n\t\tif (route.children && Array.isArray(route.children) && route.children.length > 0) {\n\t\t\tif (checkPathInRoutes(route.children, path)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n}\n\n/**\n * 判断路径是否存在于vue-router对象中(兼容Vue2和Vue3)\n * @param router vue-router实例\n * @param path 需要检查的页面路径\n * @returns 路径是否存在\n */\nexport function isRouteExists(router: any, path: string): boolean {\n\t// 移除路径中的查询参数\n\tif (path.includes('?')) {\n\t\tpath = path.split('?')[0];\n\t}\n\tconst routes = getRouterPaths(router);\n\tif (!routes || routes.length === 0) return false;\n\treturn checkPathInRoutes(routes, path);\n}\n\n// 净化单个路由配置,只保留安全字段\nfunction purifyRoute(route) {\n\t// 只提取需要的基础字段,根据你的需求调整\n\tconst safeFields = {\n\t\tpath: route.path,\n\t\tname: route.name,\n\t\tmeta: route.meta || {}, // 确保meta是普通对象\n\t\tredirect: route.redirect,\n\t\t// 剔除 component、beforeEnter 等可能包含函数/对象引用的字段\n\t\t// 如果需要children,递归净化\n\t\tchildren: route.children ? route.children.map((child) => purifyRoute(child)) : [],\n\t};\n\n\t// 进一步净化meta(如果meta中可能有复杂对象)\n\tsafeFields.meta = JSON.parse(JSON.stringify(safeFields.meta));\n\n\treturn safeFields;\n}\n\n/**\n * 获取路由路径\n *\n */\nexport function getRouterPaths(router: any): any[] {\n\tlet routes: any[] = [];\n\t// 区分Vue Router 3.x (Vue2) 和 4.x (Vue3)\n\tif (typeof router.getRoutes === 'function') {\n\t\t// Vue Router 4.x (Vue3)\n\t\troutes = router.getRoutes();\n\t} else if (router.options && Array.isArray(router.options.routes)) {\n\t\t// Vue Router 3.x (Vue2)\n\t\troutes = router.options.routes;\n\t}\n\treturn routes.map((route) => purifyRoute(route)) || [];\n}\n\n/**\n * 比较两个URL的协议、IP(或域名)和端口是否完全相同\n * @param url1 第一个URL字符串\n * @param url2 第二个URL字符串\n * @returns 如果协议、IP(或域名)和端口都相同则返回true,否则返回false;解析失败时返回false\n */\nexport function areUrlsSameProtocolIpPort(url1: string, url2: string): boolean {\n\ttry {\n\t\t// 解析两个URL\n\t\tconst parsedUrl1 = new URL(url1);\n\t\tconst parsedUrl2 = new URL(url2);\n\n\t\t// 比较协议(不区分大小写,但通常URL协议是小写的)\n\t\tconst sameProtocol = parsedUrl1.protocol.toLowerCase() === parsedUrl2.protocol.toLowerCase();\n\n\t\t// 比较主机(IP或域名)\n\t\tconst sameHost = parsedUrl1.hostname === parsedUrl2.hostname;\n\n\t\t// 比较端口(如果未指定端口,会使用协议默认端口)\n\t\tconst samePort = parsedUrl1.port === parsedUrl2.port;\n\n\t\t// 只有所有部分都相同时才返回true\n\t\treturn sameProtocol && sameHost && samePort;\n\t} catch (error) {\n\t\t// 如果URL解析失败,返回false\n\t\tconsole.error('URL解析错误:', error);\n\t\treturn false;\n\t}\n}\n\nexport const getCircularReplacer = () => {\n\tconst seen = new WeakSet();\n\treturn (key, value) => {\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tif (seen.has(value)) {\n\t\t\t\t// 遇到循环引用时,返回一个标识或忽略\n\t\t\t\treturn '[Circular Reference]';\n\t\t\t}\n\t\t\tseen.add(value);\n\t\t}\n\t\treturn value;\n\t};\n};\n\nexport function getBaseRoute(routers: any[], url: string): string {\n\tlet baseRoute = '';\n\tlet urlObj = new URL(url);\n\tlet noQueryUrl = url.split('?')[0];\n\n\t// 判断路由模式并取值\n\tlet routePath = '';\n\tif (urlObj.hash && urlObj.hash.indexOf('#/') > -1) {\n\t\troutePath = urlObj.hash.split('#')[1];\n\n\t} else {\n\t\troutePath = urlObj.pathname;\n\t}\n\n\tconsole.log(routePath);\n\t\n\t// 当前路由中没有该路由,判定有base\n\tif (!isRouteMatched(routers, routePath)) {\n\t\t// 尝试剔除第一个路由,再判断是否匹配\n\t\tlet arr = routePath.split('/');\n\t\tlet nowRoute = '/' + arr.slice(2, arr.length).join('/');\n\t\tconsole.log(routers, nowRoute);\n\t\t\n\t\tif (isRouteMatched(routers, nowRoute)) {\n\t\t\tbaseRoute = '/' + arr[1];\n\t\t} else {\n\t\t\tconsole.error('仅支持vue-router一级base配置');\n\t\t}\n\t}\n\treturn baseRoute;\n}\n","import Postmate from './postMeta';\nimport { getCircularReplacer, getRouterPaths, isRouteExists } from './tools';\n\ninterface EventObj {\n\terror: (error: any) => void;\n\tsuccess: (success: any) => void;\n\treceive: (receive: any) => void;\n}\n\n// 路由更新接口\ninterface RouteUpdateInfo {\n\tfullPath: string;\n\t[x: string]: any;\n}\n\nexport default class ChildPostmate {\n\tchildPostmate: any = null;\n\tparentPostmate: any = null;\n\n\tisGetData: boolean = false;\n\tgetDataCllBack: Function | null = null;\n\tstateOver: boolean = false;\n\n\t// Vue Router实例\n\trouter: any = null;\n\t// 路由更新回调函数\n\tcustomRouteChange: ((routeInfo: RouteUpdateInfo) => void) | undefined = undefined;\n\n\tconstructor(eventObj: EventObj, router: any, customRouteChange?: (routeInfo: RouteUpdateInfo) => void) {\n\t\t// 保存router实例\n\t\tthis.router = router;\n\t\t// 保存路由更新回调函数\n\t\tthis.customRouteChange = customRouteChange;\n\n\t\tif (window.top !== window.self) {\n\t\t\tthis.init(eventObj);\n\t\t\tsetTimeout(() => {\n\t\t\t\tif (this.stateOver) return;\n\t\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t\t}, 500);\n\t\t} else {\n\t\t\teventObj.error({ status: 500, data: null, message: '未在一体化平台中运行' });\n\t\t}\n\t}\n\n\tinit(eventObj: EventObj) {\n\t\tconst that = this;\n\t\t// 创建 Postmate Model(作为子)\n\t\tthis.childPostmate = new Postmate.Model({\n\t\t\t// 定义子页面可以暴露给父页面的方法\n\t\t\tbaseData(data: any) {\n\t\t\t\tdata = JSON.parse(data);\n\t\t\t\tif (that.isGetData) {\n\t\t\t\t\tthat.getDataCllBack &&\n\t\t\t\t\t\tthat.getDataCllBack({\n\t\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\t\tdata: data,\n\t\t\t\t\t\t});\n\t\t\t\t} else\n\t\t\t\t\teventObj.receive({\n\t\t\t\t\t\tstatus: 200,\n\t\t\t\t\t\tmessage: 'success',\n\t\t\t\t\t\tdata: data,\n\t\t\t\t\t});\n\t\t\t\tthat.isGetData = false;\n\t\t\t},\n\n\t\t\t// 提供当前系统的路由\n\t\t\tgetRoutes: () => {\n\t\t\t\t// 有路由\n\t\t\t\tif (that.router) {\n\t\t\t\t\tlet arr = getRouterPaths(that.router);\n\t\t\t\t\tthat.parentPostmate.emit('pushRoutes', JSON.stringify(arr, getCircularReplacer()));\n\t\t\t\t}\n\t\t\t\t// 无路由\n\t\t\t\telse that.parentPostmate.emit('pushRoutes');\n\t\t\t},\n\n\t\t\t// 检查路由是否存在\n\t\t\tisRouteExists(routePath: string) {\n\t\t\t\tif (that.router) that.parentPostmate.emit('routeExists', isRouteExists(that.router, routePath));\n\t\t\t\telse that.parentPostmate.emit('routeExists', false);\n\t\t\t},\n\n\t\t\t// 处理路由更新\n\t\t\trouteUpdate(routeInfoStr: string) {\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\ttry {\n\t\t\t\t\tconst routeInfo: RouteUpdateInfo = JSON.parse(routeInfoStr);\n\n\t\t\t\t\t// 如果提供了自定义的路由更新回调函数,则调用它\n\t\t\t\t\tif (that.customRouteChange) {\n\t\t\t\t\t\tthat.customRouteChange(routeInfo);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\t// 如果提供了router实例,则使用router进行路由更新\n\t\t\t\t\tif (that.router) {\n\t\t\t\t\t\tthat.router.replace(routeInfo.fullPath);\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', true);\n\t\t\t\t\t\tconsole.log('----------------- 【ChildPastMate】路由更新完成 -----------------');\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t\t\tconsole.warn('【ChildPastMate】未提供router实例,无法进行路由更新');\n\t\t\t\t\t}\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsole.error('【ChildPastMate】路由更新失败:', error);\n\t\t\t\t\tthat.parentPostmate.emit('route_update_result', false);\n\t\t\t\t}\n\t\t\t},\n\t\t})\n\t\t\t.then((parent: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\tthat.parentPostmate = parent;\n\t\t\t\tthat.getData();\n\t\t\t\t// 与父页面链接建立成功\n\t\t\t\teventObj.success({\n\t\t\t\t\tstatus: 200,\n\t\t\t\t\tmessage: 'success',\n\t\t\t\t\tdata: {\n\t\t\t\t\t\tChildPostmate: parent,\n\t\t\t\t\t},\n\t\t\t\t});\n\t\t\t\t// 告诉父系统支持路由更新\n\t\t\t\tthat.parentPostmate.emit('route_update_support', that.router ? true : false);\n\n\t\t\t\t// 向父页面同步路由数据\n\t\t\t\tthat.router && that.parentPostmate.emit('pushRoutes', JSON.stringify(getRouterPaths(that.router), getCircularReplacer()));\n\t\t\t})\n\t\t\t.catch((err: any) => {\n\t\t\t\tthis.stateOver = true;\n\t\t\t\teventObj.error({ status: 500, data: null, message: err });\n\t\t\t});\n\t}\n\n\t// 获取数据\n\tgetData(callback?: any) {\n\t\tif (!this.parentPostmate) {\n\t\t\tcallback({\n\t\t\t\tstatus: 500,\n\t\t\t\tmessage: '父页面未连接',\n\t\t\t\tdata: null,\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\n\t\tif (callback) {\n\t\t\tthis.isGetData = true;\n\t\t\tthis.getDataCllBack = callback;\n\t\t} else {\n\t\t\tthis.isGetData = false;\n\t\t\tthis.getDataCllBack = null;\n\t\t}\n\t\t// 向父页面获取数据\n\t\tthis.parentPostmate.emit('requestBaseData');\n\t}\n\n\t/**\n\t * 设置路由实例和路由更新回调\n\t * @param router Vue Router实例\n\t * @param customRouteChange 自定义路由更新回调函数\n\t */\n\tsetRouter(router: any, customRouteChange?: (routeInfo: RouteUpdateInfo) => void) {\n\t\tthis.router = router;\n\t\tif (customRouteChange) {\n\t\t\tthis.customRouteChange = customRouteChange;\n\t\t}\n\t}\n\n\t/**\n\t * 向父页面发送其他请求\n\t * @param params 请求参数\n\t */\n\tsendOtherRequest(params: any) {\n\t\tif (!this.parentPostmate) return;\n\t\tthis.parentPostmate.emit('otherRequest', params);\n\t}\n}\n","import Postmate from './postMeta';\nimport { isRouteMatched } from './RouteMatching';\nimport { areUrlsSameProtocolIpPort, checkPathInRoutes, getBaseRoute } from './tools';\n\ninterface DataInfo {\n loginInfo: { [x: string]: any };\n token: string;\n isHideHeader: boolean;\n}\n\n// URL解析结果接口\ninterface ParsedUrl {\n protocol: string;\n host: string;\n port: string;\n pathname: string;\n search: string;\n hash: string;\n origin: string;\n fullPath: string;\n}\n\nexport default class ParentPostmate {\n /** 连接到的子 postmate 实例 */\n postmateParent: any = null;\n /** 通讯数据 */\n dataInfo: DataInfo = {\n loginInfo: {},\n token: '',\n isHideHeader: true,\n };\n /** iframe Dom 容器 */\n iframeEle: any = null;\n /** 当前 iframe url */\n currentUrl: string = '';\n /** 存储当前的 iframe 元素 */\n currentIframe: any = null;\n /** iframe 加载完成执行函数 */\n loadFunction: (() => void) | null = null;\n /** 处理子类的其他请求方法 */\n handleOtherRequest: ((params: any) => void) | null = null;\n /** 子页面是否支持路由更新 */\n childSupportsRouteUpdate: boolean = true;\n /** 子系统的路由列表 */\n childRoutes: any[] = [];\n\n eventBus: any = {\n getRoutes: null,\n route_update_result: null,\n };\n\n constructor(\n dataInfo: DataInfo,\n iframeEle: HTMLElement | (() => HTMLElement),\n iframeUrl: string = '',\n handleOtherRequest?: (params: any) => void,\n ) {\n this.dataInfo = dataInfo || this.dataInfo;\n this.iframeEle = iframeEle;\n this.setIframeUrl(iframeUrl);\n handleOtherRequest && (this.handleOtherRequest = handleOtherRequest);\n }\n\n /** 解析URL */\n parseUrl(url: string): ParsedUrl {\n const link = document.createElement('a');\n link.href = url;\n\n // 获取协议\n const protocol = link.protocol.length > 4 ? link.protocol : window.location.protocol;\n\n // 获取主机和端口\n const host = link.hostname;\n const port =\n link.port || (protocol === 'https:' ? '443' : protocol === 'http:' ? '80' : '');\n\n // 获取路径、查询参数和哈希\n const pathname = link.pathname.startsWith('/') ? link.pathname : `/${link.pathname}`;\n const search = link.search;\n const hash = link.hash.slice(2, link.hash.length);\n\n // 构建origin\n const origin = link.origin || `${protocol}//${host}${port ? `:${port}` : ''}`;\n\n // 构建完整路径(不包含origin)\n const fullPath = `${pathname}${hash}`;\n\n return {\n protocol,\n host,\n port,\n pathname,\n search,\n hash,\n origin,\n fullPath,\n };\n }\n\n /** 比较两个URL是否相同*/\n compareUrlBase(url1: string, url2: string): boolean {\n const url1End = url1.endsWith('/');\n const url2End = url2.endsWith('/');\n if ((url1End && url2End) || (!url1End && !url2End)) {\n return url1 === url2;\n } else {\n if (url1End) url2 += '/';\n if (url2End) url1 += '/';\n return url1 === url2;\n }\n }\n\n /** 比较两个URL的路径是否相同(不包含查询参数和哈希) */\n compareUrlPath(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.pathname === parsed2.pathname;\n }\n\n /** 比较两个URL是否完全相同(包括查询参数和哈希) */\n compareUrlFull(url1: string, url2: string): boolean {\n if (!url1 || !url2) return false;\n\n const parsed1 = this.parseUrl(url1);\n const parsed2 = this.parseUrl(url2);\n\n return parsed1.fullPath === parsed2.fullPath;\n }\n\n /** 清除当前的 iframe 和 postmate 实例 */\n clear() {\n // 销毁 postmate 实例\n if (this.postmateParent) {\n this.postmateParent.destroy();\n this.postmateParent = null;\n }\n\n this.eventBus.getRoutes = null;\n this.eventBus.route_update_result = null;\n this.childRoutes = [];\n this.childSupportsRouteUpdate = false;\n\n // 移除 iframe\n if (this.currentIframe && this.currentIframe.parentNode) {\n this.currentIframe.parentNode.removeChild(this.currentIframe);\n }\n this.currentIframe = null;\n }\n\n /** 初始化 */\n async init(callback: any = null) {\n // 清除之前的实例和 iframe\n this.clear();\n\n // 重置子页面路由更新支持标记\n this.childSupportsRouteUpdate = false;\n\n // 如果没有容器,或集成链接\n if (!this.iframeEle || !this.currentUrl) {\n this.destroy();\n return;\n }\n\n // 获取 iframe 容器\n const container: any =\n typeof this.iframeEle === 'function' ? this.iframeEle() : this.iframeEle;\n if (!container) {\n console.warn('【ParentPostmate】无法获取 iframe 容器');\n return;\n }\n\n // 创建 Postmate 实例(作为父)\n const handshake: any = new Postmate({\n container,\n url: this.currentUrl,\n name: '',\n model: '',\n });\n\n // 存储当前创建的 iframe\n this.currentIframe = container.querySelector('iframe');\n this.currentIframe.setAttribute('frameborder', '0');\n this.currentIframe.setAttribute('allow', 'fullscreen');\n this.currentIframe.addEventListener('load', () => {\n this.loadFunction && this.loadFunction();\n });\n\n handshake\n .then((parent: any) => {\n this.postmateParent = parent;\n\n // 监听子页面发来的获取数据请求\n parent.on('requestBaseData', () => {\n // 发送相关数据\n this.sendData();\n });\n\n // 监听子页面发来的路由配置数据\n parent.on('pushRoutes', (routes: string) => {\n if (routes) this.childRoutes = JSON.parse(routes);\n else this.childRoutes = [];\n this.eventBus.getRoutes && this.eventBus.getRoutes();\n });\n\n // 监听子页面的路由效验结果\n parent.on('routeExists', (flag: boolean) => {});\n\n // 监听子页面的动态路由变更支持\n parent.on('route_update_support', (flag: boolean) => {\n this.childSupportsRouteUpdate = flag;\n });\n\n // 监听子页面的路由变更结果\n parent.on('route_update_result', (flag: boolean) => {\n this.eventBus.route_update_result && this.eventBus.route_update_result(flag);\n });\n\n // 监听子页面发来的其他请求\n parent.on('otherRequest', (params: any) => {\n this.handleOtherRequest && this.handleOtherRequest(params);\n });\n\n if (typeof callback === 'function') callback();\n })\n .catch((error: any) => {\n console.error('【ParentPostmate】Postmate 连接失败:', error);\n });\n }\n\n /** 设置load执行事件 */\n setLoadFunction(loadFunction: () => void) {\n this.loadFunction = loadFunction;\n }\n\n /** 设置 iframe url */\n setIframeUrl(iframeUrl: string, routerPath: string = '') {\n // 如果完全一样:不操作\n if (iframeUrl === this.currentUrl) return;\n\n // 如果传入了路由,则对路径进行规范处理\n if (routerPath && !routerPath.startsWith('/')) {\n routerPath = '/' + routerPath;\n }\n\n if (routerPath && routerPath.endsWith('/')) {\n routerPath = routerPath.slice(0, -1);\n }\n\n // 1、传入的地址为空:销毁当前实例\n if (!iframeUrl) {\n this.currentUrl = '';\n this.destroy();\n console.error('【ParentPostmate】无加载地址,无法初始化');\n return;\n }\n\n // 2、如果当前无连接:直接设置并初始化\n if (!this.postmateParent || !this.currentUrl) {\n this.currentUrl = iframeUrl;\n if (this.iframeEle) this.init();\n else console.error('【ParentPostmate】无 iframe 容器,无法初始化');\n return;\n }\n\n // 3、如果当前系统不支持路由更新 或 新旧系统协议、ip、端口不同则重新初始化: 重新初始化\n if (\n !this.childSupportsRouteUpdate ||\n !this.childRoutes?.length ||\n !areUrlsSameProtocolIpPort(this.currentUrl, iframeUrl)\n ) {\n this.currentUrl = iframeUrl;\n this.init();\n return;\n }\n\n /**\n * 因新旧地址的基础地址完全相同,且已加载系统支持路由更新\n * 下面处理新旧地址的url,研判操作方式\n **/\n // 更新路由列表\n let flag = false;\n this.eventBus.getRoutes = () => {\n flag = true;\n this.handleSimilarUrl(iframeUrl, routerPath);\n };\n this.postmateParent.call('getRoutes');\n\n setTimeout(() => {\n if (flag) return;\n this.handleSimilarUrl(iframeUrl, routerPath);\n }, 1000);\n }\n\n // 处理相似地址\n handleSimilarUrl(iframeUrl: string, routerPath?: string) {\n let hasQuery = iframeUrl.split('?').length > 1;\n let urlQuery = '';\n // 判断是否携带参数\n if (hasQuery) urlQuery = '?' + iframeUrl.split('?')[1];\n\n // 1 如果传入了routerPath,将该值与子系统匹配,判断是否可以直接跳转\n if (routerPath && isRouteMatched(this.childRoutes, routerPath)) {\n this.sendRouteUpdate({\n fullPath: routerPath + urlQuery,\n });\n this.currentUrl = iframeUrl;\n return;\n }\n\n // 2 手动解析地址中的routePath,并考虑是否携带基础地址\n // 获取基础地址\n const baseRoute = getBaseRoute(this.childRoutes, this.currentUrl);\n // 获取新链接的路由地址\n let urlObj = new URL(iframeUrl);\n let routePath = '';\n if (urlObj.hash && urlObj.hash.indexOf('#/') > -1) {\n routePath = urlObj.hash.split('#')[1];\n } else {\n routePath = urlObj.pathname + urlQuery;\n }\n console.log(this.childRoutes, routePath.replace(baseRoute, ''));\n\n if (\n this.currentUrl.split(baseRoute)[0] === iframeUrl.split(baseRoute)[0] &&\n isRouteMatched(this.childRoutes, routePath.replace(baseRoute, ''))\n ) {\n // 触发更新路由\n this.sendRouteUpdate({\n fullPath: routePath.replace(baseRoute, ''),\n });\n console.log('推送地址:', iframeUrl);\n console.log('推送路由:', routePath.replace(baseRoute, ''));\n console.log('当前地址:', this.currentUrl);\n\n this.currentUrl = iframeUrl;\n return;\n }\n\n // 3 如果以上两种情况都不满足,则重新初始化\n this.currentUrl = iframeUrl;\n this.init();\n }\n\n /** 向子页面发送路由更新消息 */\n sendRouteUpdate(parsedUrl: any) {\n try {\n let flag = false;\n this.eventBus.route_update_result = (state: boolean) => {\n flag = state;\n this.loadFunction && this.loadFunction();\n };\n this.postmateParent.call('routeUpdate', JSON.stringify(parsedUrl));\n console.log(\n '---------------------- 【ParentPostmate】推送路由更新 ----------------------',\n );\n setTimeout(() => {\n if (flag) return;\n console.warn('【ParentPostmate】推送路由更新失败,将重新初始化iframe');\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }, 1000);\n } catch (error) {\n console.warn('【ParentPostmate】发送路由更新消息失败,将重新初始化iframe:', error);\n // 标记子页面不支持路由更新\n this.childSupportsRouteUpdate = false;\n // 如果发送消息失败,则重新初始化iframe\n this.init();\n }\n }\n\n /** 向子页面发送消息 */\n sendData() {\n if (!this.postmateParent) return;\n this.postmateParent.call('baseData', JSON.stringify(this.dataInfo));\n }\n\n /** 销毁实例 */\n destroy() {\n this.clear();\n }\n}\n"],"names":["MESSAGE_TYPE","uid","allowedPostmateTypes","isValidMessage","event","allowedOrigin","ParentAPI","config","value","name","data","property","Postmate","resolve","id","handler","method","callback","ChildAPI","postmate","result","res","eventName","container","model","url","classListArray","origin","link","protocol","host","attemptCount","interval","reject","listener","send","init","Model","parentModel","key","normalizeBase","base","trimmed","extractRelativePath","fullAddress","normalizedBase","pathname","normalizedPathname","relativePath","convertRoutePathToRegex","routePath","regexStr","_","__","regex","traverseRoutes","routers","targetRelativePath","parentPath","normalizedTarget","route","processedParentPath","processedRoutePath","fullRoutePath","isRouteMatched","checkPathInRoutes","routes","path","isRouteExists","router","getRouterPaths","purifyRoute","safeFields","child","areUrlsSameProtocolIpPort","url1","url2","parsedUrl1","parsedUrl2","sameProtocol","sameHost","samePort","error","getCircularReplacer","seen","getBaseRoute","baseRoute","urlObj","arr","nowRoute","ChildPostmate","eventObj","customRouteChange","that","routeInfoStr","routeInfo","parent","err","params","ParentPostmate","dataInfo","iframeEle","iframeUrl","handleOtherRequest","port","search","hash","fullPath","url1End","url2End","parsed1","parsed2","handshake","flag","loadFunction","routerPath","_a","hasQuery","urlQuery","parsedUrl","state"],"mappings":"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"}
|
|
@@ -5,6 +5,7 @@ interface EventObj {
|
|
|
5
5
|
}
|
|
6
6
|
interface RouteUpdateInfo {
|
|
7
7
|
fullPath: string;
|
|
8
|
+
[x: string]: any;
|
|
8
9
|
}
|
|
9
10
|
export default class ChildPostmate {
|
|
10
11
|
childPostmate: any;
|
|
@@ -13,16 +14,16 @@ export default class ChildPostmate {
|
|
|
13
14
|
getDataCllBack: Function | null;
|
|
14
15
|
stateOver: boolean;
|
|
15
16
|
router: any;
|
|
16
|
-
|
|
17
|
-
constructor(eventObj: EventObj, router: any,
|
|
17
|
+
customRouteChange: ((routeInfo: RouteUpdateInfo) => void) | undefined;
|
|
18
|
+
constructor(eventObj: EventObj, router: any, customRouteChange?: (routeInfo: RouteUpdateInfo) => void);
|
|
18
19
|
init(eventObj: EventObj): void;
|
|
19
20
|
getData(callback?: any): void;
|
|
20
21
|
/**
|
|
21
22
|
* 设置路由实例和路由更新回调
|
|
22
23
|
* @param router Vue Router实例
|
|
23
|
-
* @param
|
|
24
|
+
* @param customRouteChange 自定义路由更新回调函数
|
|
24
25
|
*/
|
|
25
|
-
setRouter(router: any,
|
|
26
|
+
setRouter(router: any, customRouteChange?: (routeInfo: RouteUpdateInfo) => void): void;
|
|
26
27
|
/**
|
|
27
28
|
* 向父页面发送其他请求
|
|
28
29
|
* @param params 请求参数
|
package/lib/postMeta/tools.d.ts
CHANGED
|
@@ -25,3 +25,4 @@ export declare function getRouterPaths(router: any): any[];
|
|
|
25
25
|
*/
|
|
26
26
|
export declare function areUrlsSameProtocolIpPort(url1: string, url2: string): boolean;
|
|
27
27
|
export declare const getCircularReplacer: () => (key: any, value: any) => any;
|
|
28
|
+
export declare function getBaseRoute(routers: any[], url: string): string;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "qlfy-postmate",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.3.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"types": "lib/index.d.ts",
|
|
6
6
|
"module": "lib/index.umd.js",
|
|
@@ -27,7 +27,8 @@
|
|
|
27
27
|
"rollup-plugin-copy": "^3.5.0",
|
|
28
28
|
"vite-plugin-compression": "^0.5.1",
|
|
29
29
|
"vite-plugin-dts": "^4.5.4",
|
|
30
|
-
"vue": "^3.5.13"
|
|
30
|
+
"vue": "^3.5.13",
|
|
31
|
+
"vue-router": "^4.6.4"
|
|
31
32
|
},
|
|
32
33
|
"devDependencies": {
|
|
33
34
|
"@tsconfig/node22": "^22.0.1",
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
interface EventObj {
|
|
2
|
-
error: (error: any) => void;
|
|
3
|
-
success: (success: any) => void;
|
|
4
|
-
receive: (receive: any) => void;
|
|
5
|
-
}
|
|
6
|
-
interface RouteUpdateInfo {
|
|
7
|
-
fullPath: string;
|
|
8
|
-
pathname: string;
|
|
9
|
-
search: string;
|
|
10
|
-
hash: string;
|
|
11
|
-
}
|
|
12
|
-
export default class ChildPostmate {
|
|
13
|
-
childPostmate: any;
|
|
14
|
-
parentPostmate: any;
|
|
15
|
-
isGetData: boolean;
|
|
16
|
-
getDataCllBack: Function | null;
|
|
17
|
-
router: any;
|
|
18
|
-
routeUpdateCallback: ((routeInfo: RouteUpdateInfo) => void) | null;
|
|
19
|
-
constructor(eventObj: EventObj, router: any, routeUpdateCallback?: (routeInfo: RouteUpdateInfo) => void);
|
|
20
|
-
init(eventObj: EventObj): void;
|
|
21
|
-
getData(callback?: any): void;
|
|
22
|
-
/**
|
|
23
|
-
* 设置路由实例和路由更新回调
|
|
24
|
-
* @param router Vue Router实例
|
|
25
|
-
* @param routeUpdateCallback 自定义路由更新回调函数
|
|
26
|
-
*/
|
|
27
|
-
setRouter(router: any, routeUpdateCallback?: (routeInfo: RouteUpdateInfo) => void): void;
|
|
28
|
-
/**
|
|
29
|
-
* 向父页面发送其他请求
|
|
30
|
-
* @param params 请求参数
|
|
31
|
-
*/
|
|
32
|
-
sendOtherRequest(params: any): void;
|
|
33
|
-
}
|
|
34
|
-
export {};
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
interface DataInfo {
|
|
2
|
-
loginInfo: {
|
|
3
|
-
[x: string]: any;
|
|
4
|
-
};
|
|
5
|
-
token: string;
|
|
6
|
-
isHideHeader: boolean;
|
|
7
|
-
}
|
|
8
|
-
interface ParsedUrl {
|
|
9
|
-
protocol: string;
|
|
10
|
-
host: string;
|
|
11
|
-
port: string;
|
|
12
|
-
pathname: string;
|
|
13
|
-
search: string;
|
|
14
|
-
hash: string;
|
|
15
|
-
origin: string;
|
|
16
|
-
fullPath: string;
|
|
17
|
-
}
|
|
18
|
-
export default class ParentPostmate {
|
|
19
|
-
/** 连接到的子 postmate 实例 */
|
|
20
|
-
postmateParent: any;
|
|
21
|
-
/** 通讯数据 */
|
|
22
|
-
dataInfo: DataInfo;
|
|
23
|
-
/** iframe Dom 容器 */
|
|
24
|
-
iframeEle: any;
|
|
25
|
-
/** 当前 iframe url */
|
|
26
|
-
currentUrl: string;
|
|
27
|
-
/** 存储当前的 iframe 元素 */
|
|
28
|
-
currentIframe: any;
|
|
29
|
-
/** iframe 加载完成执行函数 */
|
|
30
|
-
loadFunction: (() => void) | null;
|
|
31
|
-
/** 处理子类的其他请求方法 */
|
|
32
|
-
handleOtherRequest: ((params: any) => void) | null;
|
|
33
|
-
/** 当前URL解析结果 */
|
|
34
|
-
parsedCurrentUrl: ParsedUrl | null;
|
|
35
|
-
/** 子页面是否支持路由更新 */
|
|
36
|
-
childSupportsRouteUpdate: boolean;
|
|
37
|
-
constructor(dataInfo: DataInfo, iframeEle: HTMLElement | (() => HTMLElement), iframeUrl?: string, handleOtherRequest?: (params: any) => void);
|
|
38
|
-
/** 解析URL */
|
|
39
|
-
parseUrl(url: string): ParsedUrl;
|
|
40
|
-
/** 比较两个URL是否相同(协议、主机、端口) */
|
|
41
|
-
compareUrlBase(url1: string, url2: string): boolean;
|
|
42
|
-
/** 比较两个URL的路径是否相同(不包含查询参数和哈希) */
|
|
43
|
-
compareUrlPath(url1: string, url2: string): boolean;
|
|
44
|
-
/** 比较两个URL是否完全相同(包括查询参数和哈希) */
|
|
45
|
-
compareUrlFull(url1: string, url2: string): boolean;
|
|
46
|
-
/** 清除当前的 iframe 和 postmate 实例 */
|
|
47
|
-
clear(): void;
|
|
48
|
-
/** 初始化 */
|
|
49
|
-
init(callback?: any): Promise<void>;
|
|
50
|
-
/** 设置load执行事件 */
|
|
51
|
-
setLoadFunction(loadFunction: any): void;
|
|
52
|
-
/** 设置 iframe url */
|
|
53
|
-
setIframeUrl(iframeUrl: string): void;
|
|
54
|
-
/** 向子页面发送路由更新消息 */
|
|
55
|
-
sendRouteUpdate(parsedUrl: ParsedUrl): void;
|
|
56
|
-
/** 向子页面发送消息 */
|
|
57
|
-
sendData(): void;
|
|
58
|
-
/** 销毁实例 */
|
|
59
|
-
destroy(): void;
|
|
60
|
-
}
|
|
61
|
-
export {};
|