를 확보할 차례입니다...">
,需要通过父级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은 전 세계 소비자들에게 고품질 제품과 서비스를 제공하기 위해 최선을 다하고 있습니다. 우리는 고객 중심의 사고방식을 가진 팀으로, 고객이 우리의 모든 활동에 만족할 수 있도록 노력하고 있습니다. 우리는 고객을 깊이 이해하고, 그들의 요구에 가장 적합한 솔루션을 함께 찾아갑니다. XIEHE MEDICAL은 단순한 공장이 아닙니다. 또한 귀하의 비즈니스 성장을 지원하고 성공을 이룰 수 있도록 돕는 종합 서비스 파트너입니다. 관 운반대를 처음 사용하는 경우든 최고의 실천 방법을 찾고 있는 경우든, 여기에는 장의사들이 직면할 수 있는 일반적인 문제들에 대한 개요가 있습니다. 주의 깊게 살펴봐야 할 주요 사항 중 하나는 운반대에 너무 많은 무게를 실어놓는 것입니다. 이는 단순히 운반대에 불필요한 부담을 주는 것을 넘어 직원과 사망자 모두에게 안전 위험을 초래할 수 있습니다. 관을 올리기 전에 항상 운반대의 허용 적재 하중을 확인해야 합니다. 피해야 할 두 번째로 흔한 문제는 운반대의 부적절한 사용입니다. 하지만 기억하세요: 사고를 방지하고 관이 긁히는 일을 막기 위해 운반대는 부드럽고 천천히 움직여야 합니다. 또한 운반대의 이동을 방해할 수 있는 장애물이 없는지 항상 주의 깊게 확인해야 합니다. 운송 중에 관이 움직이거나 떨어지는 일이 없도록 관이 운반대에 제대로 고정되었는지도 반드시 확인하십시오. 장례업계: 관 운반대는 장의사에게 매우 소중한 도구로, 사용자들이 존엄한 장례식 중에 관을 안전하고 효율적으로 이동할 수 있도록 해줍니다. 관 운반용으로 제작된 이 운반대는 관의 무게와 크기에 적합하게 설계되어 장의사가 관을 한 장소에서 다른 장소로 옮기는 작업을 보다 쉽게 할 수 있습니다. 관 운반대가 없다면, 장의사들은 순전히 인력이나 임시 대체 수단을 이용해 관을 옮겨야만 했을 것이며, 이는 고된 작업일 뿐 아니라 위험할 수도 있는 과정이었을 것입니다. 이들은 고인을 한 장소에서 다른 장소로 옮길 때 고인에게 존엄성과 존중을 유지할 수 있도록 도와줄 수 있습니다. 카트를 사용하면 관을 옮기는 과정에서 어색한 운반 또는 사고를 방지할 수 있습니다. 또한 카트는 장례 서비스의 일상적인 운영을 더욱 효율적으로 만들어주며, 장례 지도사들이 관을 어떻게 옮길지를 걱정하는 대신 유가족 보호에 더 집중할 수 있도록 해줍니다. 협화 메디컬 애파러터스 인스트루먼츠는 전문화된 글로벌 마케팅 및 판매를 전문으로 합니다. 지난 10년간 파트너사들의 지지와 노력 덕분에 현재 전 세계에 30개 이상의 유통사를 보유하고 있으며, 제품은 120개 이상의 국가로 유통되고 있습니다. 관료용 카트(코핀 트롤리) 분야에 집중하여 유통사 및 시스템 통합업체와의 장기적인 협력 관계를 구축하고, 함께 미래를 설계하고 구현해 나가고자 합니다. 협화 메디컬 애파러터스 인스트루먼츠는 신제품 개발(R&D)과 경쟁력 있는 판매 포인트를 갖춘 제품 공급에 강한 전념을 다하고 있습니다. 특허 및 지적재산권을 보유한 의료용 스테처용 관상차, 응급의료용 제품, 병원용 가구 및 장례용 제품을 생산합니다. 당사의 제품은 고객의 수요를 충족시키고 현재의 시장 트렌드와 부합하도록 설계되었습니다. 이러한 제품들은 국내외 고객들로부터 높은 호응을 얻고 있습니다. 허허 의료장비는 고객 만족을 우선으로 하며, 고객의 요구에 맞춘 우수하고 신뢰할 수 있는 관인 운반차를 제공하기 위해 노력하고 있습니다. 열정적인 직원들과 협력적인 기술 덕분에 우리는 고객에게 세심하고 주의 깊은 서비스를 제공할 수 있으며, 그들의 요구가 효과적으로 충족되도록 합니다. 우리는 팀워크와 기술 지원을 통해 고객과 장기적이고 안정된 협력을 구축하고, 고품질의 제품과 서비스를 제공합니다. 전문 의료기기 제조업체로서 협화 메디컬 애파러터스 인스트루먼츠는 고품질 제품과 맞춤형 전문 서비스를 제공합니다. 엄격히 ISO 13485 품질 관리 시스템을 준수하며, 당사 모든 제품은 TÜV, CE, FDA 등 다양한 국제 인증을 획득하였습니다. 고객의 수요에 신속히 대응할 수 있는 관상차 전담 팀을 보유하여 고품질이자 안정적인 제품을 공급합니다. 구급차용 스테처, 접이식 스테처, 병원용 가구 또는 장례용 품목이 필요할 때, 협화 메디컬 장비가 최적의 해답을 제공합니다.관材 수레
도매 구매를 위한 고품질 관 운반대

관 운반대 공급업체를 선택할 때 고려해야 할 사항

관 운반대 사용 시 피해야 할 일반적인 문제들

장의사에게 관 운반대가 필수적인 이유
Why choose XIEHE MEDICAL
관材 수레?
글로벌 마케팅 네트워크와 안정적인 파트너십
혁신적인 연구 개발 및 제품 판매 포인트
고객 중심의 빠른 애프터 서비스 및 기술 지원
고품질의 제품과 특화된 서비스
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기