From 6840e3c18e307f45e138c65dcd25ae4c68e1e496 Mon Sep 17 00:00:00 2001 From: bailicangdu <1264889788@qq.com> Date: Mon, 19 Aug 2024 22:29:13 +0800 Subject: [PATCH 1/3] fix(1.0.0-rc.7): fix bug of with sandbox when child rewrite history.pushstate/replaceState --- docs/zh-cn/changelog.md | 1 + src/sandbox/router/history.ts | 26 ++++++++++++++------------ 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/docs/zh-cn/changelog.md b/docs/zh-cn/changelog.md index 2a403d1b..51c3fb9a 100644 --- a/docs/zh-cn/changelog.md +++ b/docs/zh-cn/changelog.md @@ -14,6 +14,7 @@ - **Bug Fix** - 🐞 修复 vue3子应用初始化时,`createWebHistory()`参数为空导致默认页面跳转异常的问题,[issue 1317](https://github.com/micro-zoe/micro-app/issues/1317)、[issue 1318](https://github.com/micro-zoe/micro-app/issues/1318)、[issue 1335](https://github.com/micro-zoe/micro-app/issues/1335)。 + - 🐞 修复 with沙箱下子应用重写`history.pushState`、`history.replaceState`失败的问题。 - **Update** - 🚀 更新 内存优化相关文档。 diff --git a/src/sandbox/router/history.ts b/src/sandbox/router/history.ts index c1cec0af..8e29b2ec 100644 --- a/src/sandbox/router/history.ts +++ b/src/sandbox/router/history.ts @@ -75,32 +75,34 @@ export function createMicroHistory (appName: string, microLocation: MicroLocatio } } - const pushState = getMicroHistoryMethod('pushState') - const replaceState = getMicroHistoryMethod('replaceState') + const originalHistory = { + pushState: getMicroHistoryMethod('pushState'), + replaceState: getMicroHistoryMethod('replaceState'), + } if (isIframeSandbox(appName)) { - return { - pushState, - replaceState, + return assign({ go (delta?: number) { return rawHistory.go(delta) } - } as MicroHistory + }, originalHistory) as MicroHistory } return new Proxy(rawHistory, { get (target: History, key: PropertyKey): HistoryProxyValue { - if (key === 'state') { + if (key === 'pushState' || key === 'replaceState') { + return originalHistory[key] + } else if (key === 'state') { return getMicroState(appName) - } else if (key === 'pushState') { - return pushState - } else if (key === 'replaceState') { - return replaceState } return bindFunctionToRawTarget(Reflect.get(target, key), target, 'HISTORY') }, set (target: History, key: PropertyKey, value: unknown): boolean { - Reflect.set(target, key, value) + if (key === 'pushState' || key === 'replaceState') { + originalHistory[key] = value as CallableFunction + } else { + Reflect.set(target, key, value) + } /** * If the set() method returns false, and the assignment happened in strict-mode code, a TypeError will be thrown. * e.g. history.state = {} From aa9dd3c54a8f2f5b14d2283b7e20361930bb399e Mon Sep 17 00:00:00 2001 From: bailicangdu <1264889788@qq.com> Date: Tue, 20 Aug 2024 17:53:21 +0800 Subject: [PATCH 2/3] chore(1.0.0-rc.8): remove some TODO list --- docs/zh-cn/changelog.md | 9 ++++++++- src/micro_app_element.ts | 5 ++--- src/sandbox/router/history.ts | 1 - 3 files changed, 10 insertions(+), 5 deletions(-) diff --git a/docs/zh-cn/changelog.md b/docs/zh-cn/changelog.md index 51c3fb9a..6a5bae9f 100644 --- a/docs/zh-cn/changelog.md +++ b/docs/zh-cn/changelog.md @@ -8,13 +8,20 @@ --- +### 1.0.0-rc.8 + +`2024-8-20` + +- **Bug Fix** + - 🐞 修复 with沙箱下子应用重写`history.pushState`、`history.replaceState`失败的问题,[issue 1210](https://github.com/micro-zoe/micro-app/issues/1210)。 + + ### 1.0.0-rc.7 `2024-8-20` - **Bug Fix** - 🐞 修复 vue3子应用初始化时,`createWebHistory()`参数为空导致默认页面跳转异常的问题,[issue 1317](https://github.com/micro-zoe/micro-app/issues/1317)、[issue 1318](https://github.com/micro-zoe/micro-app/issues/1318)、[issue 1335](https://github.com/micro-zoe/micro-app/issues/1335)。 - - 🐞 修复 with沙箱下子应用重写`history.pushState`、`history.replaceState`失败的问题。 - **Update** - 🚀 更新 内存优化相关文档。 diff --git a/src/micro_app_element.ts b/src/micro_app_element.ts index 0edcaeff..43c41a46 100644 --- a/src/micro_app_element.ts +++ b/src/micro_app_element.ts @@ -147,7 +147,7 @@ export function defineElement (tagName: string): void { if ( attr === ObservedAttrName.URL && ( !this.appUrl || - !this.connectStateMap.get(this.connectedCount) // TODO: 这里的逻辑可否再优化一下 + !this.connectStateMap.get(this.connectedCount) ) ) { newVal = formatAppURL(newVal, this.appName) @@ -159,7 +159,7 @@ export function defineElement (tagName: string): void { } else if ( attr === ObservedAttrName.NAME && ( !this.appName || - !this.connectStateMap.get(this.connectedCount) // TODO: 这里的逻辑可否再优化一下 + !this.connectStateMap.get(this.connectedCount) ) ) { const formatNewName = formatAppName(newVal) @@ -168,7 +168,6 @@ export function defineElement (tagName: string): void { return logError(`Invalid attribute name ${newVal}`, this.appName) } - // TODO: 当micro-app还未插入文档中就修改name,逻辑可否再优化一下 if (this.cacheData) { microApp.setData(formatNewName, this.cacheData) this.cacheData = null diff --git a/src/sandbox/router/history.ts b/src/sandbox/router/history.ts index 8e29b2ec..d2087261 100644 --- a/src/sandbox/router/history.ts +++ b/src/sandbox/router/history.ts @@ -221,7 +221,6 @@ function reWriteHistoryMethod (method: History['pushState' | 'replaceState']): C excludeHiddenApp: true, excludePreRender: true, }).forEach(appName => { - // TODO: 大部分情况下,history.pushState 都是先执行,micro-app后卸载,所以会产生一种情况:跳转到新地址后,search模式会在url上添加参数,卸载后再将参数删除,所以会导致浏览器地址闪烁,是否需要去掉这个功能 if ((isRouterModeSearch(appName) || isRouterModeState(appName)) && !getMicroPathFromURL(appName)) { const app = appInstanceMap.get(appName)! attachRouteToBrowserURL( From b87562c533505198f202e8b3e07c61eecd247b6f Mon Sep 17 00:00:00 2001 From: bailicangdu <1264889788@qq.com> Date: Tue, 20 Aug 2024 17:54:47 +0800 Subject: [PATCH 3/3] chore(1.0.0-rc.8): update version --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index a8889a2f..96498c3d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@micro-zoe/micro-app", - "version": "1.0.0-rc.7", + "version": "1.0.0-rc.8", "description": "A lightweight, efficient and powerful micro front-end framework", "private": false, "main": "lib/index.min.js",