...">
,需要通过父级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);
}
});
})();
Om du är en campingentusiast eller ofta har utomhusaktiviteter, vill du då ha en god natt med din partner bredvid dig? Kolla in Granskningssofa campingbädd enkel! RokForm Rugged Portabla Stånd är byggt robust och redo att låta dig sova som stjärnorna på natten, oavsett var du är. Lätt och portabel är campingbädden ett av de bästa valen bland grossistvaror för camping – köp den nu till de lägsta priserna från Sveriges ledande webbshop för campingbäddar! Så låt oss titta på alla skäl till varför DET HÄR är något du absolut måste ha med dig på din nästa vildmarksutflykt! Campingbädd - Stark utomhus 4,5 av 5 stjärnor 13 $40,4016' Xtra-Komfort Influerbar Höjd Camping Ventilerad - Komplig bärsekk, luftpump blå, kompakt … Funktion: Liggande XXGEF Gäller för: Vuxen, Vikbar: Nej Stil: fiske, Strand, Sängstorlek: enkel Material: Högsta vattenavvisande nivå: L30000 mm golv Paket inkluderar: 1 x campingsäng Obs: Ljus vid fotografering och olika skärmar kan orsaka att färgen på föremålet i bilden skiljer sig något från det verkliga föremålet. Oavsett om du sätter upp läger i bergen eller vid kusten ger denna robusta bår dig en stadig och säker sömn. Hållbar konstruktion garanterar lång livslängd och kan enkelt bära din vikt även under påfrestande förhållanden utan att gå sönder. Dessutom gör den portabla konstruktionen av denna bår att du kan ta med den överallt och slå läger för att utnyttja ett nytt äventyr. En av de främsta fördelarna med XIEHE MEDICAL:s campingbår singel är hur lätt och portabel den är. Denna bår är inte stor och tung som vanliga campingfält, den kan vikas ihop och packas ner i en liten bärpåse. Detta är perfekt för backpackare och campare som behöver hålla nere vikten och storleken på sin utrustning. Oavsett om du campar i skogen eller bara ska över till en väns för en pyjamasfest, ha denna fällsäng till hands så att en skön sömn alltid är nära. En vilsam natts sömn är ett måste efter en dag fylld med äventyr i det fria, och vi har dig täckt med naturens bästa vilarbädd. Vår XIEHE MEDICAL campingsbädd för en person har designats med din komfort i åtanke – den stora sängen med full bredd är tillverkad av ett andningsbart tyg som gör att du sover bekvämare. Den genomtänkta ergonomin i denna bädd ger dig utmärkt stöd så att du kan slappna av och ladda energin inför nästa dags äventyr! Adjö till de obekväma, hårda sovmattorna och välkommen till en god natts sömn (ja, DET FINNS en sovsbädd för dig med denna bekväma campingsbädd). När det gäller utomhusutrustning i allmänhet är hållbarhet och kvalitet den viktigaste faktorn. Bärsängen för en person från XIEHE MEDICAL är konstruerad med kvalitetsmaterial för att säkerställa långvarig användning. Oavsett om du campar under het, fuktig väderlek eller på en kall natt, kommer denna bärsäng klara elementens påfrestningar. Denna överlägsna campingbärsäng ger dig komfort för alla de fantastiska upplevelserna i naturen under många år framöver, med ordentlig vård och underhåll. Skaffa dig en pålitlig och bekväm plats för en god natts sömn med XIEHE MEDICAL Camp Stretcher Single! Om du är en partihandlare som letar efter billiga campingutrustningar, då är XIEHE MEDICAL:s campingsbädd för en person din perfekta allt-i-ett-lösning. Det är inte ett dåligt pris... det är ett utmärkt värde för en solitt produkt – robust i design men fortfarande portabel – en bädd som gungar!! Oavsett om du utrustar din detaljbutik eller uthyrningstjänst kommer denna campingsbädd att tillfredsställa dina kunder utan att tömma plånboken. Byggd för att imponera på kunder med ett prisvärt och slitstarkt campingpaket som kompletterar deras upplevelse utomhus. Xiehe Medical Apparatus Instruments campingbår – enskild modell för global marknadsföring och försäljning. Under de senaste 10 åren av arbete och med stöd av våra partners har vi idag över 30 distributörer världen över. Våra produkter finns tillgängliga i över 120 länder. Vi fokuserar på att skapa långsiktiga partnerskap med integratörer samt distributörer för att tillsammans bygga framtidens lösningar. Hehe Medical Equipment prioriterar kundnöjdhet och strävar efter att uppfylla kundernas krav på excellens och tillförlitlighet när det gäller campingbärbar bår – enkel. Våra engagerade medarbetare och samarbetsinriktade teknik gör det möjligt för oss att erbjuda nära, uppmärksamma tjänster till våra kunder, så att deras behov effektivt tillgodoses. Vi strävar efter att etablera ett långsiktigt och stabilt samarbete med våra kunder och leverera högkvalitativa produkter och tjänster genom teamarbete och teknisk support. Xiehe Medical Apparatus & Instruments är kontinuerligt engagerad i kreativ forskning och utveckling (R&D) och är dedikerad åt att erbjuda produkter med konkurrenskraftiga säljargument. Patent och immateriella rättigheter skyddar bland annat campingbärbara bår – enkel, första hjälpen-utrustning, möbler för sjukhus samt begravningssprodukter. Produkterna är utformade för att följa aktuella trender och möta våra kunders behov. De uppskattas både av inhemska och utländska kunder. Som professionell tillverkare av medicinskt utrustningsmaterial erbjuder Xiehe Medical Apparatus Instruments högkvalitativa produkter och specialiserade tjänster. Vi implementerar strikt ISO13485-kvalitetskontrollsystem, och alla våra produkter är certifierade av TUV, CE, FDA och flera andra. Vi har ett team inom campingbårar med enkel funktion som kan svara snabbt på kundens behov och leverera högkvalitativa och stabila produkter. När du behöver en ambulansbädd eller viktbädd möbler för sjukhus och begravningstjänster, har Xiehe Medical Equipment lösningen.campingbädd enskild
Lättviktig och kompakt design för enkel transport

Komfortabel ensamstående campingsbädd för en vilsam natts sömn

Pålitlig kvalitet och slitstarkt material för utomhusbruk

Perfekt lösning för partihandlare som söker prisvärda campingutrustningar
Why choose XIEHE MEDICAL
campingbädd enskild?
Global marknadsföringsnätverk och stabila partner
Kundcentrerad snabb efterförsäljningstjänst och teknisk support
Innovativ forskning och utveckling samt produktsäljpunkter
Högkvalitativa produkter och specialiserade tjänster
Hittar du inte det du letar efter?
Begär offert nu
Kontakta våra konsulter för fler tillgängliga produkter.Kontakta oss