— 안전한 폐기용:
XIEHE MEDICAL은 최고 품질의 ...
">
,需要通过父级DOM结构来判断
*/
var trackActionPhone = function (node) {
var nodeInnerText = node.innerText || '';
if (!limitRegLength(nodeInnerText)) return;
var nodeText = trimText(nodeInnerText);
if (nodeText.length < 5 || nodeText.length > 20) return false;
var type =
arguments.length > 1 && arguments[1] !== undefined
? arguments[1]
: 'click';
var str = trimText(node.href || node.innerHTML || '');
if (phoneReg.test(str) && numUseReg.test(str)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
/** 排查父级嵌套非标签场景,并且对dom的正则校验做一个性能兜底,通过控制innerText的长度,来确保正则的性能 */
var fatherText = trimText(node.parentNode.innerText || '');
if (fatherText.length < 5 || fatherText.length > 20) return false;
var fatherDom = trimText(node.parentNode.innerHTML || '');
if (phoneReg.test(fatherDom) && numUseReg.test(fatherDom)) {
_paq.push(['trackEvent', type, 'phone', nodeText]);
return true;
}
return false;
};
window.addEventListener('click', function (e) {
var node = e.target;
/** 社媒点击 */
var appName = '';
var getAppAriaLabel =
node.ariaLabel || node.parentNode.ariaLabel || '';
if (mediaList.includes(getAppAriaLabel.toLowerCase())) {
appName = getAppAriaLabel;
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'a'
) {
appName = getMediaName(node.href) || getMediaName(node.alt);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'img'
) {
appName = getMediaName(node.alt) || getMediaName(node.src);
}
if (
!appName &&
node.nodeName &&
node.nodeName.toLowerCase() === 'i'
) {
appName = getMediaName(node.className);
}
if (appName) {
_paq.push(['trackEvent', 'click', 'contactApp', appName]);
return;
}
/** 联系方式点击 */
if (trackActionPhone(node, 'click')) return;
if (node.nodeName && node.nodeName.toLowerCase() === 'a') {
var val = node.href;
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
if (node.nodeName && node.nodeName.toLowerCase() === 'i') {
var val = node.className;
var content = node.parentNode.href || '';
if (val.includes('email')) {
_paq.push(['trackEvent', 'click', 'email', content]);
return;
}
}
var nodeChildList = node.childNodes;
for (var i = 0; i < nodeChildList.length; i++) {
if (nodeChildList[i].nodeType !== 3) continue;
var val = nodeChildList[i].textContent.replace(/\s?:?/g, '');
if (!limitRegLength(val)) continue;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'click', 'email', val]);
return;
}
}
trackNumberData(node);
});
window.addEventListener('copy', function (e) {
if (trackActionPhone(e.target, 'copy')) return;
var text = e.target.textContent;
if (!text) return;
var val = text.replace(/\s:?/g, '');
if (!limitRegLength(val)) return;
if (emailReg.test(val)) {
_paq.push(['trackEvent', 'copy', 'email', val]);
return;
}
trackNumberData(e.target);
});
}
trackContactInit();
/**
* 基于custom_inquiry_form.js 以及 form.js 对于询盘表单提交的实现,来反推询盘表单的input标签触发,用来收集意向客户
* 1. 缓存的KEY:TRACK_INPUT_ID_MTM_00;
* 2. 缓存策略 - lockTrackInput:单个页面内,10分钟内,不重复上报
*/
function trackActionInput() {
const CACHE_KEY = 'TRACK_INPUT_ID_MTM_00';
const pathName = window.location.hostname + window.location.pathname;
var lockTrackInput = function () {
try {
const lastCacheData = localStorage.getItem(CACHE_KEY);
if (!lastCacheData) return false;
const cacheData = JSON.parse(lastCacheData);
const cacheTime = cacheData[pathName];
if (!cacheTime) return false;
return Date.now() - cacheTime < 1000 * 60 * 10; // 10分钟内,不重复上报
} catch (error) {
console.error('lockTrackInput Error', error);
return false;
}
};
var setInputTrackId = function () {
try {
const curCacheData = localStorage.getItem(CACHE_KEY);
if (curCacheData) {
const cacheData = JSON.parse(curCacheData);
cacheData[pathName] = Date.now();
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
return;
}
const cacheData = {
[pathName]: Date.now(),
};
localStorage.setItem(CACHE_KEY, JSON.stringify(cacheData));
} catch (error) {
console.error('setInputTrackId Error', error);
}
};
var getInputDom = function (initDom) {
var ele = initDom;
while (ele) {
/**
* isWebSiteForm 是站点的表单
* isChatWindowForm 是聊天窗口的表单
*/
/** 旧模板表单 */
var isWebSiteForm = !!(
/crm-form/i.test(ele.className) && ele.querySelector('form')
);
/** 1:新模板自定义表单、2:Get a Quote 弹框表单 */
var isWebSiteFormNew = !!(
/inquiry/i.test(ele.className) && ele.querySelector('form')
);
if (isWebSiteForm || isWebSiteFormNew) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'page']);
setInputTrackId();
return;
}
/** Mkt会话触达-聊天弹框的表单输入: MKT由于是iframe嵌入,所以MKT的上报,会单独写到MKT-form代码上 */
var isInquiryChatForm = !!(
/comp-form/i.test(ele.className) && ele.querySelector('form')
);
if (isInquiryChatForm) {
_paq.push(['trackEvent', 'formInquiry', 'formInput', 'chat']);
setInputTrackId();
return;
}
/** 向上查找父节点 */
ele = ele.parentNode;
}
};
function initInputListener() {
var inputUseDebounce = function (fn, delay) {
var timer = null;
var that = this;
return function () {
var args = Array.prototype.slice.call(arguments);
if (timer) clearTimeout(timer);
timer = setTimeout(function () {
fn.apply(that, args);
}, delay);
};
};
var optimizeGetInputDom = inputUseDebounce(getInputDom, 300);
window.addEventListener('input', function (e) {
/** 如果已经上报过,则不再上报 */
if (lockTrackInput()) return;
optimizeGetInputDom(e.target);
});
}
try {
initInputListener();
} catch (error) {
console.log('initInputListener Error', error);
}
}
trackActionInput();
}
/** 第三方消息上报:目前主要是针对全点托管会话;在msgCollect/index.js中调试,访问test.html */
function thirdMsgCollect() {
/** 先检测是否是stayReal托管:如果stayReal脚本都没有,那么说明当前站点未开启stayReal会话托管 */
const scriptList = Array.prototype.slice.call(
document.querySelectorAll('script'),
);
const checkStayReal = () =>
!!scriptList.find((s) => s.src.includes('stayreal.xiaoman.cn'));
if (!checkStayReal()) return;
/** 缓存当前消息队列的最后一条消息id */
const CACHE_KEY = 'CACHE_KEY_MONITOR';
const setCache = (msgIndex) => {
/** 对缓存KEY进行base64转码处理 */
const cacheMsgIndex = btoa(msgIndex);
localStorage.setItem(CACHE_KEY, cacheMsgIndex);
};
const getCache = () => {
const cacheMsgIndex = localStorage.getItem(CACHE_KEY);
if (cacheMsgIndex) return Number(atob(cacheMsgIndex));
return -1;
};
/** 拉取最新msg列表 */
const pullMsgList = () => {
const msgEleList = Array.prototype.slice.call(
document.querySelectorAll('#chat-list li'),
);
const msgIds = [];
const msgMap = msgEleList.reduce((acc, item) => {
const sendTime = item
.querySelector('.message-data-time')
.textContent.trim();
const sendContent = item.querySelector('.message').textContent.trim();
/** msg带有class:other-message的是访客消息,my-message的是客服消息 */
const isOtherMessage = item
.querySelector('.message')
.classList.contains('other-message');
const msgId = item.querySelector('.message').getAttribute('id');
const msgItemData = {
msgId,
user: isOtherMessage ? 'visitor' : 'official',
time: sendTime,
content: sendContent,
};
msgIds.push(msgId);
acc[msgId] = msgItemData;
return acc;
}, {});
return {
ids: msgIds,
dataMap: msgMap,
};
};
/** 加密并上传消息数据 */
let ENCRYPT_KEY = 'de29f1aab63ab033';
let ENCRYPT_IV = 'b8d2badf875e76ac';
const baseUrl = 'https://cms.xiaoman.cn';
// var getEncryptConfig = function () {
// const url = baseUrl + '/shop-api/innerApi/getKeyIv'
// $.get(
// url,
// function (result) {
// console.log('result', result)
// if (Number(result.code) === 0 && result.data.key && result.data.iv) {
// ENCRYPT_KEY = result.data.key
// ENCRYPT_IV = result.data.iv
// uploadMsgData()
// } else {
// /** 如果获取失败,则重试 */
// setTimeout(() => {
// getEncryptConfig()
// }, 1000)
// }
// },
// 'json'
// )
// }
// getEncryptConfig()
const encryptMsg = function (msgData) {
const enc = new TextEncoder();
// 转字节
const keyBytes = enc.encode(ENCRYPT_KEY);
const ivBytes = enc.encode(ENCRYPT_IV);
const plainBytes = enc.encode(msgData);
// 导入密钥并加密
return crypto.subtle
.importKey('raw', keyBytes, { name: 'AES-CBC' }, false, ['encrypt'])
.then(function (cryptoKey) {
return crypto.subtle.encrypt(
{ name: 'AES-CBC', iv: ivBytes },
cryptoKey,
plainBytes,
);
})
.then(function (encryptedBuffer) {
// 转 base64 返回
return btoa(
String.fromCharCode(...new Uint8Array(encryptedBuffer)),
);
})
.catch((err) => {
return Promise.reject(err);
});
};
let uploadFlag = false;
const uploadMsgData = function () {
if (uploadFlag) return;
uploadFlag = true;
const { ids, dataMap } = pullMsgList();
let cacheMsgIndex = getCache();
const msgLen = ids.length;
if (!msgLen) {
// 消息DOM未挂载 || 消息DOM已挂载,但是消息列表为空
uploadFlag = false;
return;
}
if (msgLen - 1 < cacheMsgIndex) {
/** 针对站点挂后台一段时间,消息列表会自动塞入重复消息,导致消息有重复,刷新后又重置回正常消息列表,所以这里需要更新锚点下标 */
cacheMsgIndex = msgLen - 1;
setCache(cacheMsgIndex);
uploadFlag = false;
return;
}
if (msgLen - 1 === cacheMsgIndex) {
// 缓存的最后一次发送的消息ID是最后一条(说明当前消息均已经上报),则不跳过本地上报
uploadFlag = false;
return;
}
const currentMsgIds = ids.slice(cacheMsgIndex + 1, msgLen);
const currentMsgData = currentMsgIds.map((id) => dataMap[id]);
const mtmId = window.matomo_site_id_cookie_key || ''; // 获取mtm会话id
const msgBody = {
mtmId,
curl: window.location.href,
msgList: currentMsgData,
};
const msgBodyStr = JSON.stringify(msgBody);
encryptMsg(msgBodyStr)
.then(function (encryptedMsg) {
console.log('encryptedMsg:', encryptedMsg, msgBodyStr);
const url = baseUrl + '/shop-api/External/ListenSiteActiveStatus';
$.ajax({
type: 'POST',
url,
data: JSON.stringify({ d_v: encryptedMsg }),
contentType: 'application/json',
success: function (result) {
if (Number(result.code) === 0) {
// 更新消息队列
setCache(msgLen - 1);
}
uploadFlag = false;
},
error: function (err) {
console.error(err, '请求异常');
uploadFlag = false;
},
});
})
.catch((err) => {
console.error(err, '数据加密失败');
uploadFlag = false;
});
};
/** 监控chat-list的DOM变更 */
const initChatListObserver = () => {
// 需要监听的 DOM 节点
const target = document.getElementById('chat-list');
if (!target) return;
// 回调函数
const callback = function (mutationsList, observer) {
for (const mutation of mutationsList) {
console.log('mutation', mutation);
if (mutation.type === 'childList') {
uploadMsgData();
}
}
};
// 配置
const config = {
childList: true, // 监听子节点的增删
subtree: true, // 是否也监听后代节点
};
// 创建 observer
const observer = new MutationObserver(callback);
// 开始监听
observer.observe(target, config);
};
let testCount = 30;
let itv = null;
const checkChatDom = () => !!document.querySelector('#vc-model');
const initTalkCheck = () => {
itv = setTimeout(() => {
console.log('checkChatDom', checkChatDom(), testCount);
if (!checkChatDom() && testCount > 0) {
testCount--;
initTalkCheck();
return;
}
clearTimeout(itv);
uploadMsgData();
initChatListObserver();
}, 1500);
};
initTalkCheck();
}
try {
gtmTrack();
thirdMsgCollect();
console.log('inserted gtm code');
} catch (error) {
console.error('gtmTrack Error', error);
}
});
})();
고품질 샤프스 박스 안전한 폐기를 위해: XIEHE MEDICAL은 유해 폐기물을 처리하기 위해 필요한 최고의 의료용 첨예물 보관함을 제공합니다. 당사의 첨예물 보관함은 바늘, 주사기 및 기타 날카로운 물체를 안전하게 수거하고 폐기하는 데 이상적입니다. 견고한 구조와 잠금이 가능한 뚜껑을 특징으로 하는 이 보관함은 의료 폐기물이 발생하는 병원, 실험실 및 기타 장소에 안전한 솔루션을 제공합니다. XIEHE MEDICAL 첨예물 보관함을 사용하면 직원과 환자가 첨예물 취급 시 위험에 노출되는 것을 방지할 수 있습니다. 합리적인 가격으로 도매로 찌르는 물체용 수거함 구매: XIEHE MEDICAL은 경쟁력 있는 PASMO II 공급업체로서, 도매 제공에 특화되어 있습니다. 샤프스 박스 귀하의 비즈니스를 위해, 재사용이 가능한 PASMO II 제품도 다양하게 보유하고 있습니다. XIEHE MEDICAL에서 대량으로 찌르는 물체용 수거함을 구매하면 비용을 절감할 수 있으며, 찌르는 물체 폐기를 위한 용기를 항상 확보할 수 있습니다. 당사는 병원, 클리닉, 약국 및 지속적으로 많은 양의 찌르는 물체용 수거함이 필요한 기타 기관에 도매 서비스를 제공합니다. XIEHE MEDICAL을 통해 폐기물 관리 프로세스를 깨끗하고 효과적으로 유지할 수 있도록 고품질의 찌르는 물체용 수거함을 저렴한 가격에 제공합니다. 최고의 제품을 구입할 수 있는 장소 바늘류 전용 용기 대량으로: 고성능 샤프스 컨테이너를 도매로 구입하고 싶다면, XIEHE MEDICAL을 방문해 보세요! 모든 의료 환경에서 사용할 수 있는 다양한 효과적이고 안전한 샤프스 컨테이너를 제공합니다. 당사의 샤프스 용기는 견고한 소재로 제작되었으며 관련 안전 기준을 모두 준수하여 샤프스 폐기물의 안전한 폐기를 가능하게 합니다. DP273 사양 모델 번호 DP301 설명 바늘 파쇄기 전압(V) 220/110 전력(W)18 포장 크기(cm):43 2714 재질 ABS 색상 노란색 인증서 CE0598, ISO9001, ISO13485 적용 대상: 스테이플러용, 전선 절단용 주사바늘/주사기 직경 없는 바늘도 쉽게 조각으로 분쇄 가능하며, 길이: 19cm 제품 태그: 벤치탑 바늘 파쇄기 약국, 수의학 진료소 또는 타투 전문 예술가라도 - XIEHE는 각 요구사항에 맞는 적합한 솔루션을 제공합니다. 당사에서 대량 구매함으로써 비용을 절감하고 항상 충분한 수량의 샤프스 용기를 확보할 수 있습니다. 샤프스 용기를 올바르게 사용하는 방법은 무엇인가요? 예민한 도구의 안전한 폐기는 부상과 감염을 피하기 위해 필수적입니다. XIEHE MEDICAL 예물함을 사용하여 의료용 날카로운 물체를 안전하게 폐기할 수 있도록 근무 중에 예물함을 올바르게 사용하는 방법을 아는 것이 중요합니다. 사용한 날카로운 물체는 즉시 예물함에 버려야 하며, 폐기 전에 바늘을 다시 뚜껑으로 덮거나 구부리려고 시도해서는 안 됩니다. 예물함이 가득 찼을 경우, 뚜껑을 닫고 테이프로 단단히 밀봉하여 유출 사고를 방지하십시오. 예물함 폐기가 필요한 경우, 지방 청소 서비스(폐기물 관리 업체) 또는 보건 관리 기관에 연락하여 안내를 받으세요. XIEHE MEDICAL 예물함을 올바르게 사용하면 어린이나 방문 근로자 등 접촉할 수 있는 다른 사람들도 날카로운 물체로 인한 부상 위험에 노출되지 않도록 보호할 수 있습니다. 예물함 용품의 최고 할인 혜택을 찾을 수 있는 곳: 샤프스 빈 용품의 최고 혜택을 찾고 계신가요? XIEHE MEDICAL이 그 해답입니다. 당사의 모든 샤프스 빈 및 액세서리에 적용되는 경쟁력 있는 가격으로 안전하고 효율적으로 의료용 날카로운 폐기물을 폐기하는 데 필요한 모든 제품을 손쉽게 비축할 수 있습니다. 샤프스 빈, 샤프스 컨테이너 또는 샤프스 폐기 키트가 필요하시다면 XIEHE MEDICAL에서 구할 수 있는 최저 가격을 제공합니다. 이제 더 이상 기다리지 마세요. 경쟁력 있는 가격과 우수한 제품으로 인해 XIEHE MEDICAL은 도시 내 최고의 샤프스 빈 용품을 보유하고 있다고 자신 있게 말씀드릴 수 있습니다! 지금 바로 우리 매장에 방문하셔서 안전한 샤프스 폐기를 위한 준비를 철저히 하세요. Xiehe Medical Apparatus Instruments는 마케팅 및 판매 분야에서 글로벌화를 추구합니다. 당사는 10년 이상에 걸친 파트너사들의 지원과 노력에 기반하여 120개 이상의 국가에서 30개 이상의 유통업체와 협력하고 있습니다. 당사는 유통업체 및 시스템 통합업체와의 장기적인 파트너십을 구축함으로써 함께 미래를 만들어가고자 합니다. Xiehe Medical Apparatus Instruments는 지속적으로 첨단 연구개발(R&D)에 참여하며 경쟁력 있는 제품의 차별화 포인트 제공에 전념하고 있습니다. 의료용 스테처, 병원 내 응급처치용 가구, 장례용 제품 등 당사의 제품들은 특허 및 지적재산권으로 보호받고 있습니다. 모든 제품은 현대적인 트렌드에 부합하도록 설계되었으며, 고객의 요구사항을 충족시킵니다. 이들 제품은 국내외 고객 모두에게 높은 평가를 받고 있습니다. 허허 의료기기에서는 고객 만족을 최우선 가치로 삼고, 날카로운 물체용 폐기함(Sharps Bin) 관련 요구 사항을 탁월함과 신뢰성으로 충족시키려 노력합니다. 당사 직원들의 헌신과 협업 기술의 활용을 바탕으로, 고객에게 개인화되고 신뢰할 수 있는 서비스를 제공할 수 있습니다. 당사의 목표는 고객과의 장기적이고 안정적이며 상호 이익이 되는 관계를 구축하고, 최고 품질의 제품 및 서비스를 제공하는 것입니다. 전문적인 의료용 날카로운 물체용 폐기함(Sharps Bin) 제조업체인 셰허 의료기기기구(Shiehe Medical Apparatus Instruments)는 고품질 제품과 전문 서비스를 동시에 제공합니다. 당사는 ISO 13485 품질 관리 프로세스를 엄격히 준수하며, 모든 제품은 TÜV, CE, FDA 등에서 인증을 받았습니다. 당사에는 고객의 요구에 신속히 대응하고 견고하며 신뢰할 수 있는 제품을 공급할 수 있는 전문가 팀이 있습니다. 응급구조용 스테처(Ambulance Stretcher), 접이식 스테처(Folding Stretcher), 병원 가구(Hospital Furniture), 장례용 품목(Funeral Items) 등 어떤 분야라도, 셰허 의료기기(Shiehe Medical Equipment)는 고객에게 만족스러운 솔루션을 제공할 수 있습니다.샤프스 박스
안전한 폐기물을 위한 고품질 찌르는 물체용 수거함

경쟁력 있는 가격으로 도매 구매 가능한 찌르는 물체용 수거함

대량으로 최고의 찌르는 물체용 수거함을 구입할 수 있는 장소

당사의 수거함을 사용하여 찌르는 물체를 올바르게 폐기하는 방법
Why choose XIEHE MEDICAL
샤프스 박스?
글로벌 마케팅 네트워크와 안정적인 파트너십
혁신적인 연구 개발 및 제품 판매 포인트
고객 중심의 빠른 애프터 서비스 및 기술 지원
고품질의 제품과 특화된 서비스
관련 제품 카테고리
족한 물체 수거
찾으시는 제품이 없으신가요?
견적 요청하기
더 많은 제품 정보를 위해 저희 컨설턴트에게 문의하십시오.문의하기