From e18eb23607c550e642f674051fd19b616c5faadd Mon Sep 17 00:00:00 2001
From: Tevin <tingquanren@163.com>
Date: Wed, 22 Nov 2023 10:22:51 +0800
Subject: [PATCH] 优化业务基类容错性

---
 bases/Pilot.js |   13 +++++++------
 1 files changed, 7 insertions(+), 6 deletions(-)

diff --git a/bases/Pilot.js b/bases/Pilot.js
index 295eb12..f5208f8 100644
--- a/bases/Pilot.js
+++ b/bases/Pilot.js
@@ -4,8 +4,7 @@
  */
 
 import Taro, { getCurrentInstance, getCurrentPages } from '@tarojs/taro';
-import { Fetcher } from './Fetcher';
-import { Tools } from '@components/common/Tools';
+import { $hostBoot } from '@components/bases/HostBoot';
 import project from '@project';
 
 export class Pilot {
@@ -92,6 +91,8 @@
     // 创建页面通讯器
     static createPoster($vm) {
         return (pageType, action, data) => {
+            // 解除引用关系
+            const nextData = JSON.parse(JSON.stringify(data || {}));
             // 下一页
             if (pageType === 'nextPage') {
                 // 持续 3 秒,检测下一页是否存在
@@ -105,7 +106,7 @@
                     const nextPage = currentPages[pageIndex + 1];
                     if (nextPage) {
                         clearInterval(timer);
-                        nextPage.$component.$onMessage(action, data);
+                        nextPage.$component?.$onMessage(action, nextData);
                     }
                 }, 50);
             } else if (pageType === 'prevPage') {
@@ -113,12 +114,12 @@
                 const pageIndex = currentPages.findIndex(page => page.$component === $vm);
                 const prevPage = currentPages[pageIndex - 1];
                 if (prevPage) {
-                    prevPage.$component.$onMessage(action, data);
+                    prevPage.$component?.$onMessage(action, nextData);
                 }
             } else if (pageType === 'rootPage') {
                 const currentPages = getCurrentPages();
                 const rootPage = currentPages[0];
-                rootPage.$component.$onMessage(action, data);
+                rootPage.$component?.$onMessage(action, nextData);
             }
         };
     }
@@ -143,7 +144,7 @@
             }
             // 小程序
             else if (process.env.TARO_ENV === 'weapp') {
-                assets2[key] = Fetcher.host + project.host.assetsPath + asset;
+                assets2[key] = $hostBoot.getHost() + project.host.assetsPath + asset;
             }
         });
         return assets2;

--
Gitblit v1.9.1