@dolphinweex/weex-harmony 0.1.76 → 0.1.78

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dolphinweex/weex-harmony",
3
- "version": "0.1.76",
3
+ "version": "0.1.78",
4
4
  "description": "weex harmony adapter",
5
5
  "main": "index.js",
6
6
  "files": [
@@ -1,6 +1,9 @@
1
1
  <template>
2
2
  <div>
3
- <!-- <text v-if="progressText.length > 0">{{progressText}}</text> -->
3
+ <div class="progress-container" v-if="progressText">
4
+ <img class="progress-loading" src="" alt="loading" />
5
+ <text class="progress-text">{{progressText}}</text>
6
+ </div>
4
7
  <iframe
5
8
  :id="embedId"
6
9
  v-if="url.length > 0 && pluginType != 'old-h5'"
@@ -40,6 +43,9 @@ export default {
40
43
  height: '0px',
41
44
  _resizeObserver: null,
42
45
  _heightCheckTimer: null,
46
+ _weexRoot: null,
47
+ _useChildrenTotalHeight: false,
48
+ _parentElement: null, // 符合条件的父级元素
43
49
  };
44
50
  },
45
51
  components: {
@@ -80,6 +86,7 @@ export default {
80
86
  if (args.progressText) {
81
87
  this.progressText = args.progressText;
82
88
  } else if (args.url) {
89
+ this.progressText = ''
83
90
  this.url = args.url;
84
91
  this.backgroundColor = args.pageBackgroundColor;
85
92
  this.pluginType = args.pluginType
@@ -124,6 +131,16 @@ export default {
124
131
  return null;
125
132
  };
126
133
  this._wrapperEl = findWrapperFromParent(); // 保存容器引用
134
+
135
+ // 直接获取父级元素,如果 hmcomponentindex 属性存在且值为 midea-common-weex-view,则保存引用
136
+ const parentEl = this.$el;
137
+ if (parentEl) {
138
+ const hmComponentIndex = parentEl.getAttribute('hmcomponentindex');
139
+ if (hmComponentIndex === 'midea-common-weex-view') {
140
+ this._parentElement = parentEl;
141
+ }
142
+ }
143
+
127
144
  // 优化手势处理性能
128
145
  this._rafId = null;
129
146
  this._pendingGesture = null;
@@ -167,6 +184,40 @@ export default {
167
184
  }
168
185
  },
169
186
 
187
+ // 计算 weex-root 所有子元素的高度总和
188
+ calculateWeexRootChildrenHeight(weexRoot) {
189
+ if (!weexRoot || !weexRoot.children || weexRoot.children.length === 0) {
190
+ return 0;
191
+ }
192
+
193
+ let totalHeight = 0;
194
+ const children = Array.from(weexRoot.children);
195
+
196
+ // 方法1: 计算所有子元素的 bottom 位置的最大值,减去第一个子元素的 top 位置
197
+ if (children.length > 0) {
198
+ const firstChildRect = children[0].getBoundingClientRect();
199
+ const rootRect = weexRoot.getBoundingClientRect();
200
+ let maxBottom = firstChildRect.bottom;
201
+
202
+ children.forEach((child) => {
203
+ const rect = child.getBoundingClientRect();
204
+ maxBottom = Math.max(maxBottom, rect.bottom);
205
+ });
206
+
207
+ totalHeight = maxBottom - rootRect.top;
208
+ }
209
+
210
+ // 如果方法1计算出的高度为0或太小,则累加所有子元素的高度
211
+ if (totalHeight <= 0) {
212
+ children.forEach((child) => {
213
+ const childHeight = child.offsetHeight || child.clientHeight || child.scrollHeight || 0;
214
+ totalHeight += childHeight;
215
+ });
216
+ }
217
+
218
+ return totalHeight;
219
+ },
220
+
170
221
  // 监听 iframe 内 .weex-root 第一个子元素或 .weex-scroller-inner 的高度
171
222
  startWeexRootHeightMonitoring() {
172
223
  // 尝试多次查找元素(因为 iframe 内容可能还在加载)
@@ -189,8 +240,9 @@ export default {
189
240
  const iframeDocument = iframe.contentDocument || iframe.contentWindow.document;
190
241
  let targetElement = null;
191
242
  let elementDesc = '';
243
+ let useChildrenTotalHeight = false; // 标记是否使用子元素总高度
192
244
 
193
- // 查找 .weex-root 的第一个子元素
245
+ // 查找 .weex-root
194
246
  const weexRoot = iframeDocument.querySelector('.weex-root');
195
247
  const weexRootFirstChild = (weexRoot && weexRoot.children.length > 0) ? weexRoot.children[0] : null;
196
248
 
@@ -199,20 +251,29 @@ export default {
199
251
 
200
252
  // 如果两个都找到了,比较高度,谁大用谁
201
253
  if (weexRootFirstChild && weexScrollerInner) {
202
- const rootHeight = weexRootFirstChild.offsetHeight || weexRootFirstChild.clientHeight || 0;
254
+ // 计算 weex-root 所有子元素的总高度
255
+ const rootChildrenTotalHeight = this.calculateWeexRootChildrenHeight(weexRoot);
256
+ const rootFirstChildHeight = weexRootFirstChild.offsetHeight || weexRootFirstChild.clientHeight || 0;
257
+ // 使用子元素总高度和第一个子元素高度的较大值
258
+ const rootHeight = Math.max(rootChildrenTotalHeight, rootFirstChildHeight);
203
259
  const scrollerHeight = weexScrollerInner.offsetHeight || weexScrollerInner.clientHeight || 0;
204
260
 
205
261
  if (rootHeight >= scrollerHeight) {
206
262
  targetElement = weexRootFirstChild;
207
- elementDesc = `.weex-root 的第一个子元素 (高度: ${rootHeight}px)`;
263
+ useChildrenTotalHeight = rootChildrenTotalHeight > rootFirstChildHeight;
264
+ elementDesc = useChildrenTotalHeight
265
+ ? `.weex-root 的所有子元素总高度 (${rootChildrenTotalHeight}px)`
266
+ : `.weex-root 的第一个子元素 (高度: ${rootHeight}px)`;
208
267
  } else {
209
268
  targetElement = weexScrollerInner;
210
269
  elementDesc = `.weex-scroller-inner (高度: ${scrollerHeight}px)`;
211
270
  }
212
271
  } else if (weexRootFirstChild) {
213
- // 只找到 .weex-root 的第一个子元素
272
+ // 只找到 .weex-root 的第一个子元素,使用所有子元素的总高度
214
273
  targetElement = weexRootFirstChild;
215
- elementDesc = '.weex-root 的第一个子元素';
274
+ useChildrenTotalHeight = true;
275
+ const rootChildrenTotalHeight = this.calculateWeexRootChildrenHeight(weexRoot);
276
+ elementDesc = `.weex-root 的所有子元素总高度 (${rootChildrenTotalHeight}px)`;
216
277
  } else if (weexScrollerInner) {
217
278
  // 只找到 .weex-scroller-inner
218
279
  targetElement = weexScrollerInner;
@@ -223,6 +284,10 @@ export default {
223
284
  if (targetElement) {
224
285
  console.log(`找到 ${elementDesc},开始监听高度变化`, targetElement);
225
286
 
287
+ // 保存 weexRoot 引用和是否使用子元素总高度的标记
288
+ this._weexRoot = weexRoot;
289
+ this._useChildrenTotalHeight = useChildrenTotalHeight;
290
+
226
291
  // 清除定时器,找到了就不再尝试
227
292
  clearInterval(this._heightCheckTimer);
228
293
 
@@ -230,10 +295,24 @@ export default {
230
295
  this.updateIframeHeightFromElement(targetElement);
231
296
 
232
297
  // 使用 ResizeObserver 监听元素高度变化
233
- this._resizeObserver = new ResizeObserver(() => {
234
- this.updateIframeHeightFromElement(targetElement);
235
- });
236
- this._resizeObserver.observe(targetElement);
298
+ // 如果使用子元素总高度,需要监听 weexRoot 的所有子元素
299
+ if (useChildrenTotalHeight && weexRoot) {
300
+ // 监听 weexRoot 本身的变化
301
+ this._resizeObserver = new ResizeObserver(() => {
302
+ this.updateIframeHeightFromElement(targetElement);
303
+ });
304
+ this._resizeObserver.observe(weexRoot);
305
+
306
+ // 同时监听所有子元素的变化
307
+ Array.from(weexRoot.children).forEach((child) => {
308
+ this._resizeObserver.observe(child);
309
+ });
310
+ } else {
311
+ this._resizeObserver = new ResizeObserver(() => {
312
+ this.updateIframeHeightFromElement(targetElement);
313
+ });
314
+ this._resizeObserver.observe(targetElement);
315
+ }
237
316
 
238
317
  } else if (attempts >= maxAttempts) {
239
318
  clearInterval(this._heightCheckTimer);
@@ -252,8 +331,17 @@ export default {
252
331
  updateIframeHeightFromElement(element) {
253
332
  if (!element) return;
254
333
 
255
- // 获取元素的实际高度
256
- const elementHeight = element.offsetHeight || element.clientHeight || element.scrollHeight;
334
+ let elementHeight = 0;
335
+
336
+ // 如果标记了使用子元素总高度,且 weexRoot 存在,计算所有子元素的总高度
337
+ if (this._useChildrenTotalHeight && this._weexRoot) {
338
+ elementHeight = this.calculateWeexRootChildrenHeight(this._weexRoot);
339
+ }
340
+
341
+ // 如果子元素总高度为0或未使用,则使用元素本身的高度
342
+ if (elementHeight <= 0) {
343
+ elementHeight = element.offsetHeight || element.clientHeight || element.scrollHeight;
344
+ }
257
345
 
258
346
  if (elementHeight > 0) {
259
347
  // 限制最大高度,防止死循环
@@ -289,7 +377,13 @@ export default {
289
377
  if (this.height !== newHeight) {
290
378
  this.height = newHeight;
291
379
  console.log(`iframe 高度已更新: ${finalHeight}px -> ${newHeight} (embedId: ${this.embedId}, max: ${maxHeight}px)`);
380
+ // 如果父级元素存在且符合条件,也给父级元素设置高度
381
+ if (this._parentElement) {
382
+ this._parentElement.style.height = `${finalHeight}px`;
383
+ }
292
384
  }
385
+
386
+
293
387
  }
294
388
  },
295
389
  handleGestureBubble(gestureData) {
@@ -349,6 +443,10 @@ export default {
349
443
  this._heightCheckTimer = null;
350
444
  }
351
445
 
446
+ // 清理引用
447
+ this._weexRoot = null;
448
+ this._useChildrenTotalHeight = false;
449
+
352
450
  // 清理RAF避免内存泄漏
353
451
  if (this._rafId) {
354
452
  cancelAnimationFrame(this._rafId);
@@ -367,4 +465,27 @@ export default {
367
465
  .common-view-iframe {
368
466
  height: 100%;
369
467
  }
468
+ .progress-container {
469
+ position: absolute;
470
+ top: 50%;
471
+ left: 50%;
472
+ transform: translate(-50%, -50%);
473
+ z-index: 10;
474
+ display: flex;
475
+ flex-direction: column;
476
+ align-items: center;
477
+ justify-content: center;
478
+ }
479
+ .progress-loading {
480
+ width:80px;
481
+ height:80px;
482
+ display: block;
483
+ margin-bottom: 40px;
484
+ }
485
+ .progress-text {
486
+ font-size: 24px;
487
+ color: #333;
488
+ text-align: center;
489
+ font-weight: 400;
490
+ }
370
491
  </style>
@@ -56,17 +56,13 @@
56
56
  >
57
57
  {{ item.label }}
58
58
  </div>
59
- <button
60
- class="edit-btn"
59
+ <img
61
60
  @click.stop.prevent="() => onEditClick(item, index)"
62
- >
63
- <img
64
- class="edit-icon"
65
- :src="''"
66
- :style="{ width: scalePx(data.editBtnSize, 24) + 'px', height: scalePx(data.editBtnSize, 24) + 'px' }"
67
- alt="编辑"
68
- />
69
- </button>
61
+ class="edit-icon"
62
+ :src="''"
63
+ :style="{ width: scalePx(data.editBtnSize, 12) + 'px', height: scalePx(data.editBtnSize, 12) + 'px' }"
64
+ alt="编辑"
65
+ />
70
66
  </div>
71
67
  </div>
72
68
  </div>
@@ -463,7 +459,6 @@
463
459
  font-weight:300
464
460
  }
465
461
  .label {
466
- width: 100%;
467
462
  text-align: center;
468
463
  white-space: nowrap;
469
464
  overflow: hidden;
@@ -473,15 +468,11 @@
473
468
  width: 100%;
474
469
  display: flex;
475
470
  align-items: center;
471
+ flex-direction: row;
472
+ justify-content: center;
476
473
  gap: 8px;
477
474
  }
478
- .edit-btn {
479
- margin-left: auto;
480
- padding: 4px 8px;
481
- border: none;
482
- border-radius: 4px;
483
- background: #f5f5f5;
484
- color: #333;
475
+ .edit-icon {
485
476
  }
486
477
  .drag-clone {
487
478
  box-sizing: border-box;