From f634a3265e87e61290a7d5b46e9532fb904e047f Mon Sep 17 00:00:00 2001 From: Tevin <tingquanren@163.com> Date: Mon, 03 Apr 2023 14:41:10 +0800 Subject: [PATCH] 优化列表卡片组件显示与交互 --- common/Tools.js | 83 +++++++++++++++++++++++++++++++++++++++++ 1 files changed, 83 insertions(+), 0 deletions(-) diff --git a/common/Tools.js b/common/Tools.js index f5d896f..8a237b8 100644 --- a/common/Tools.js +++ b/common/Tools.js @@ -533,6 +533,89 @@ return moment(dayTimestamp).format('YYYY-MM-DD'); } + /** + * 显示调试面板(仅支持H5) + * @param cssSelector + * @param callback + */ + static $_showDevConsole(cssSelector, callback) { + // 只支持 h5 编译 + if (process.env.TARO_ENV !== 'h5') { + return; + } + const fileref = document.createElement('script'); + fileref.setAttribute('type', 'text/javascript'); + if (window.location.protocol === 'https:') { + fileref.setAttribute('src', 'https://cdn.jsdelivr.net/npm/eruda'); + } else { + fileref.setAttribute('src', 'http://cdn.jsdelivr.net/npm/eruda'); + } + document.getElementsByTagName('head')[0].appendChild(fileref); + const simulateTouch = (dom, type) => { + const button = dom; + const touch = new Touch({ + identifier: Date.now(), + target: button, + clientX: 0, + clientY: 0, + screenX: 0, + screenY: 0, + pageY: 0, + pageX: 0, + radiusX: 2.5, + radiusY: 2.5, + rotationAngle: 10, + force: 0.5, + }); + const touchstart = new TouchEvent(type, { + cancelable: true, + bubbles: true, + composed: true, + touches: [touch], + targetTouches: [touch], + changedTouches: [touch], + }); + button.dispatchEvent(touchstart); + }; + const erudaTimer = setInterval(() => { + if (window.eruda) { + clearInterval(erudaTimer); + setTimeout(() => { + const container = document.createElement('div'); + if (cssSelector) { + document.querySelector(cssSelector).appendChild(container); + } else { + document.getElementsByTagName('body')[0].appendChild(container); + } + window.eruda.init({ + container: container, + useShadowDom: false, + }); + let button = null; + setTimeout(() => { + button = document.querySelector('.eruda-entry-btn'); + }, 50); + setTimeout(() => { + simulateTouch(button, 'touchstart'); + }, 60); + setTimeout(() => { + simulateTouch(button, 'touchend'); + }, 350); + setTimeout(() => { + console.warn('=====【艾信App调试模式】====='); + }, 800); + setTimeout(() => { + console.warn('点击右下角悬浮工具箱图标可以折叠面板'); + }, 900); + setTimeout(() => { + callback && callback(); + }, 1000); + }, 100); + + } + }, 100); + } + } // h5 中,实现 rem 转换 px -- Gitblit v1.9.1