@tarojs/runtime 3.4.0-beta.3 → 3.5.0-canary.1

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.
@@ -70,10 +70,9 @@ if (process.env.TARO_ENV === 'h5') {
70
70
  };
71
71
  // Load global or shim versions of Map, Set, and WeakMap
72
72
  var functionPrototype = Object.getPrototypeOf(Function);
73
- var usePolyfill = isObject(process) && process.env && process.env["REFLECT_METADATA_USE_MAP_POLYFILL"] === "true";
74
73
  var _Map = Map;
75
74
  var _Set = Set;
76
- var _WeakMap = !usePolyfill && isFunction(WeakMap) ? WeakMap : CreateWeakMapPolyfill();
75
+ var _WeakMap = isFunction(WeakMap) ? WeakMap : CreateWeakMapPolyfill();
77
76
  // [[Metadata]] internal slot
78
77
  // https://rbuckton.github.io/reflect-metadata/#ordinary-object-internal-methods-and-internal-slots
79
78
  var Metadata = new _WeakMap();
@@ -1359,14 +1358,7 @@ let TaroEventTarget = class TaroEventTarget {
1359
1358
  }
1360
1359
  addEventListener(type, handler, options) {
1361
1360
  var _a, _b;
1362
- // 某些框架,如 PReact 有委托的机制,handler 始终是同一个函数
1363
- // 这会导致多层停止冒泡失败:view -> view(handler.stop = false) -> view(handler.stop = true)
1364
- // 这样解决:view -> view(handlerA.stop = false) -> view(handlerB.stop = false)
1365
- // 因此每次绑定事件都新建一个函数,如果带来了性能问题,可以把这段逻辑抽取到 PReact 插件中。
1366
- const oldHandler = handler;
1367
- handler = function () {
1368
- oldHandler.apply(this, arguments); // this 指向 Element
1369
- };
1361
+ type = type.toLowerCase();
1370
1362
  (_b = (_a = this.hooks).onAddEvent) === null || _b === void 0 ? void 0 : _b.call(_a, type, handler, options, this);
1371
1363
  if (type === 'regionchange') {
1372
1364
  // map 组件的 regionchange 事件非常特殊,详情:https://github.com/NervJS/taro/issues/5766
@@ -1374,8 +1366,6 @@ let TaroEventTarget = class TaroEventTarget {
1374
1366
  this.addEventListener('end', handler, options);
1375
1367
  return;
1376
1368
  }
1377
- type = type.toLowerCase();
1378
- const handlers = this.__handlers[type];
1379
1369
  let isCapture = Boolean(options);
1380
1370
  let isOnce = false;
1381
1371
  if (isObject(options)) {
@@ -1391,6 +1381,16 @@ let TaroEventTarget = class TaroEventTarget {
1391
1381
  return;
1392
1382
  }
1393
1383
  process.env.NODE_ENV !== 'production' && warn(isCapture, 'Taro 暂未实现 event 的 capture 特性。');
1384
+ // 某些框架,如 PReact 有委托的机制,handler 始终是同一个函数
1385
+ // 这会导致多层停止冒泡失败:view -> view(handler.stop = false) -> view(handler.stop = true)
1386
+ // 这样解决:view -> view(handlerA.stop = false) -> view(handlerB.stop = false)
1387
+ // 因此每次绑定事件都新建一个函数,如果带来了性能问题,可以把这段逻辑抽取到 PReact 插件中。
1388
+ const oldHandler = handler;
1389
+ handler = function () {
1390
+ oldHandler.apply(this, arguments); // this 指向 Element
1391
+ };
1392
+ handler.oldHandler = oldHandler;
1393
+ const handlers = this.__handlers[type];
1394
1394
  if (isArray(handlers)) {
1395
1395
  handlers.push(handler);
1396
1396
  }
@@ -1407,7 +1407,10 @@ let TaroEventTarget = class TaroEventTarget {
1407
1407
  if (!isArray(handlers)) {
1408
1408
  return;
1409
1409
  }
1410
- const index = handlers.indexOf(handler);
1410
+ const index = handlers.findIndex(item => {
1411
+ if (item === handler || item.oldHandler === handler)
1412
+ return true;
1413
+ });
1411
1414
  process.env.NODE_ENV !== 'production' && warn(index === -1, `事件: '${type}' 没有注册在 DOM 中,因此不会被移除。`);
1412
1415
  handlers.splice(index, 1);
1413
1416
  }
@@ -2863,12 +2866,12 @@ function createEvent(event, node) {
2863
2866
  const eventsBatch = {};
2864
2867
  // 小程序的事件代理回调函数
2865
2868
  function eventHandler(event) {
2866
- var _a, _b;
2869
+ var _a, _b, _c;
2867
2870
  const hooks = getHooks();
2868
2871
  (_a = hooks.modifyMpEvent) === null || _a === void 0 ? void 0 : _a.call(hooks, event);
2869
2872
  event.currentTarget || (event.currentTarget = event.target);
2870
2873
  const currentTarget = event.currentTarget;
2871
- const id = ((_b = currentTarget.dataset) === null || _b === void 0 ? void 0 : _b.sid /** sid */) || currentTarget.id /** uid */ || '';
2874
+ const id = ((_b = currentTarget === null || currentTarget === void 0 ? void 0 : currentTarget.dataset) === null || _b === void 0 ? void 0 : _b.sid /** sid */) || (currentTarget === null || currentTarget === void 0 ? void 0 : currentTarget.id) /** uid */ || ((_c = event.detail) === null || _c === void 0 ? void 0 : _c.id) || '';
2872
2875
  const node = getDocument().getElementById(id);
2873
2876
  if (node) {
2874
2877
  const dispatch = () => {