">
,需要通过父级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 환자를 위한 조절 가능한 침대 , 이러한 담장은 환자의 편안함과 돌봄을 고려하여 설계되었으며, 보안을 저해하지 않으면서 편안한 이동을 제공하기 위해 여러 기능이 설치되었습니다. 담장은 최소 5인치 높이까지 도달할 수 있어 헬멧 등의 보호 장비를 대시보드나 좌석에 로딩하거나, 동전/벨트 지갑 스마트폰, 태블릿 등을 아래에 두는 것도 가능합니다. 구급용 스텐처는 무엇보다도 환자의 안녕과 편안함을 보장하기 위해 필요합니다. XIEHE MEDICAL 조절 가능한 병원용 침대 지지물, 부드러운 쿠션 표면, 베개 및 담요 등을 가지고 와서 환자가 이동 중일 때 편의가 줄어드는 것을 보완합니다. 또한 환자가 안전하게 고정될 수 있도록 강화된 시트 벨트를 갖추고 있습니다. 이들이 이동식이기 때문에, 구급대원들이 사용하는 이러한 도구들은 환자를 신속하고 효율적으로 이전할 수 있게 해주며, 더 신속한 의료 서비스를 제공받을 수 있도록 합니다. 다양한 환자 요구사항에 맞출 수 있는 많은 구급차용擔架들이 있습니다. 후자는 더욱 다양한 설정을 제공하여 예를 들어 기울임 각도나 높이를 조절하거나, 구급 인원이 환자를 가능한 한 가장 편안하게 할 수 있도록 모든 필요한 조치를 취할 수 있게 합니다. XIEHE MEDICAL 다리용 공기 스플린트 , 모든 크기의 환자를 위해 설계되었으며, 회사의 병원 파트너들과 함께 이 목적을 위해 특별히 제작되었습니다. 이를 통해 환자들이 이동 중 안전을 유지할 수 있습니다. 또한 일부擔架는 가벼운 무게와 접이식 구조로 설계되어 긴급 상황에서 쉽게 다룰 수 있고 휴대할 수 있습니다. 구급차용 담석은 환자의 안전과 편안함을 위해 사용됩니다; 공기 스플린트 키트 환자를 한 방향으로만 안전하게 이동시킬 수 있습니다 팁 환자를 빠르게 고정하기 위해 담석을 항상 가까이 두세요 환자를 이동하기 전에 담석의 안정성을 확인하고 모든 잠금 장치가 제대로 고정되었는지 점검하세요 환자를 앉히고 항상 안전벨트를 매세요 적절한 높이와 기울기를 맞추기 위해 담석을 재조정하세요 환자를 도와주는 동안 항상 환자를 주시하고, 이때 이동 중 환자가 안전하도록 확인하세요. 품질과 서비스는 구급차용 담석을 선택할 때 매우 중요한 요소입니다. 좋은 서비스를 제공하는 회사를 찾아야 합니다. 공기 스플린트 보증, 고객 평가와 같은 요인들에 대해 연구하여 귀하의 필요에 가장 적합한 하나를 선택하세요. Hehe Medical Equipment는 고객 만족을 최우선으로 삼으며 탁월한 신뢰성으로 고객의 요구를 충족시키기 위해 노력합니다. 직원들의 열정과 협업 기술 덕분에 고객에게 가까이 다가가 세심한 서비스를 제공할 수 있습니다. 판매용 구급차 스트레처는 고객과의 끊임없는 장기적인 협력 관계를 구축하고 고품질의 제품과 서비스를 제공하는 것을 목표로 합니다. 셰허 메디컬 기기기구(Xiehe Medical Apparatus Instruments)는 전문 제조사로서, 구급대원용 스테처를 비롯한 다양한 제품을 판매하고 있으며 고품질 제품과 맞춤형 서비스를 제공합니다. 당사는 ISO13485 품질 관리 절차를 철저히 준수하며, 모든 제품은 TÜV, CE, FDA 등 국제 인증을 획득하였습니다. 또한 고객의 수요에 신속히 대응할 수 있는 전문가 팀을 보유하고 있어, 신뢰성 높고 견고한 제품을 안정적으로 공급합니다. 구급대원용 스테처, 접이식 스테처, 병원 가구, 장례용 품목 등 어떤 제품이든, 셰허 메디컬 장비(Xiehe Medical Equipment)는 고객에게 만족스러운 솔루션을 제공할 수 있습니다. 협화 메디컬 애파러터스 인스트루먼츠(Xiehe Medical Apparatus Instruments)는 글로벌 전략 기반의 마케팅 및 판매에 전념해 왔습니다. 당사 파트너들의 10여 년에 걸친 지지와 협력을 바탕으로, 전 세계 120개국에 걸쳐 30개 이상의 유통업체를 보유하고 있습니다. 구급대용 스테처(Ambulance stretcher) 판매 사업을 통해 유통업체 및 시스템 통합업체와의 장기적 파트너십을 구축하고, 함께 미래를 창조해 나가고자 합니다. 협화 메디컬 애파러터스 인스트루먼츠(Xiehe Medical Apparatus Instruments)는 끊임없이 첨단 연구개발(R&D)에 참여하며 경쟁력 있는 제품의 차별화된 판매 포인트를 제공하는 데 헌신하고 있습니다. 의료용 스테처, 응급처치용 제품, 병원 내 가구류, 장례용 제품 등에 대한 특허 및 지적재산권이 보호되고 있습니다. 당사 제품은 시대의 흐름을 반영하여 제작되며, 고객의 다양한 니즈를 충족시키기 위해 지속적으로 업그레이드됩니다. 이 제품들은 국내외 고객들로부터 높은 평가를 받고 있습니다. 구급대용 스테처(Ambulance Stretchers): 응급의료서비스(EMS)는 사고 현장에서 의료기관까지 환자를 신속히 이송하기 위해 내구성과 견고함을 갖춘 구급대용 스테처에 크게 의존합니다. 병원: 알루미늄 스쿠프 스트레쳐 환자를 특정 환경 외부로 불필요하게(그리고 위험하게) 이동시키는 것을 최소화하기 위해 병원 내에서 한 부서에서 다른 부서로 환자를 이동시킬 때에도 사용된다. 요양원: 구급대용 스테처는 요양원 내에서 자가 이동이 불가능하거나 스스로 자기 관리가 어려운 환자의 이동을 보조하는 데 사용된다. 판매용 구급차 스텐처
왜 구급차 스텐처가 중요한가요

구급차 스텐처의 다양한 기능들

구급차 스텐처를 어떻게 활용할 것인가

적절한 스텐처를 선택하는 방법
Why choose XIEHE MEDICAL
판매용 구급차 스텐처?
고객 중심의 빠른 애프터 서비스 및 기술 지원
고품질의 제품과 특화된 서비스
글로벌 마케팅 네트워크와 안정적인 파트너십
혁신적인 연구 개발 및 제품 판매 포인트
구급대원용 스테처가 어떤 역할을 하는가
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기