. Također može af...">
,需要通过父级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);
}
});
})();
U CDPH-u prepoznajemo potrebu za dobro vođenjem spremište kontejnera također može utjecati na to koliko brzo i učinkovito možete pronaći i pohraniti svoje predmete. Proširili smo popis pogodnosti koje dobivate kada naručujete od nas, uključujući prethodno provjerene dobavljače kontejnera, proizvode koji zadovoljavaju naše visoke standarde kvalitete, česta korisna pitanja o transportnim kontejnerima koja treba uzeti u obzir, te cijene veleprodaje za nekoliko vrhunskih opcija za pohranu kontejnera kao što je uređenje vaših kontejnera. Kada je riječ o CDPH-u za vaše opcije spremišta kontejnera, imate mnogo pogodnosti na koje možete računati. Izvrsno za različite namjene, naši kontejneri su čvrsti, izdržljivi i dostupni u veličinama do dva funta. Ako trebate pohraniti hranu, osobne stvari, odjeću, alat ili vrijedne proizvode vezane uz prodaju naše kontejneri omogućuju vam da te predmete sačuvate od vremenskih uvjeta i jakog sunca, a istovremeno ih držite uredno organizirane. Povezani proizvodi I naši su spremnici jeftini i dostupni u velikom izboru veličina kako bi odgovarali vašim potrebama. Za one koji imaju potrebu za visokokvalitetnim spremište kontejnera proizvodima na veliko, CDPH ima sve. Koristimo materijale visoke kvalitete koji su dizajnirani da traju, tako da dobivate maksimalnu vrijednost za svoj novac. Imamo sve – od pločastih spremnika do providnih plastičnih spremnika s poklopcima koji pomažu u izložbi vaših artikala, i sve između toga. Kada odaberete CDPH za svoje potrebe nabave spremnika na veliko, znate da dobivate najbolje što se tiče excelentnosti proizvoda. Iako može biti potpuno korisna, organizacija spremnika ima neke uobičajene probleme na koje treba obratiti pozornost. Imamo naviku preterano punjenja ovih spremnika, a to nije osobito učinkovito kada pokušavate locirati i pronaći svoje stvari. Trebali biste redovito provjeravati svoje kutije i uklanjati nepotrebne stvari kad god je to potrebno kako biste osigurali najbolju iskorištenost prostora za pohranu. Osim toga, možete oznakama označiti svoje spremnike kako biste brzo pronašli ono što vam treba. Ovdje u CDPH-u imamo proizvode za pohranu dostupne po cijeni koju nigdje drugdje na internetu ne možete pronaći. Bez obzira trebate li samo nekoliko spremnika za osobnu uporabu ili veliku količinu za komercijalne svrhe, mi imamo sve što vam je potrebno. Naše veleprodajne cijene među najnižima su na tržištu, pa ste sigurni da ćete dobiti izvrsnu vrijednost za svoj novac. U CDPH-u posvećeni smo tome da vam donesemo visokokvalitetne proizvode za pohranu po nepristupačnim cijenama! Prefabrikirana kuća je izgrađena posebnim konstrukcijskim projektom i ima dobre seizmičke performanse kako bi se osigurala sigurnost. Modularni dizajn je jednostavan za pomicanje, instalaciju i može se prilagoditi u kontejner trgovini s vašim osobnim preferencijama različitih stilova, tipova soba. Svi elementi su izrađeni od prefabrikiranog materijala i lako se instaliraju bez potrebe za posebnim vještinama. Bilo da je namjenjena za ured, stan, skladište ili druge situacije, prefabrikirana kuća može zadovoljiti vaše potrebe. Stiliziran izgled, elegantne linije, i može se prilagoditi vašim individualnim preferencijama da stvori individualni životni prostor. Najbolje od svega je da se prefabrikirane kuće ne moraju zavarivati na licu mjesta, a mi pružamo uputstva za montažu kako bi se instalacija učinila lakšom i bržom. Prihvati prednosti života u ugodnijim kućama u Chengdongu. Chengdong prefabrikirane kuće. Apple kabin, jedinstveni oblik, prekrasan izgled, učinit će vaš dom personaliziranijim. Nudimo različite stilove i boje koje odgovaraju vašim osobnim ukusima, od jednostavnih suvremenih do retro izvedbi. Beijing Chengdong usredotočen je na korisničke želje te se može prilagoditi prema vašim potrebama. Kako biste zadovoljili svoje pojedinačne preferencije i želje, moguće je promijeniti oblik vašeg doma kao i raspored, vodovod, električnu instalaciju itd., kako biste stvorili savršen individualni dom. Unaprijed smo izgradili električne i vodovodne cjevovode, čime se izbjegava zadatak premještanja cjevovoda za vodu i struju nakon uređenja kuće, a time se poboljšava učinkovitost i kvaliteta uređenja. Nudimo širok izbor unutarnjih rasporeda koji uključuju dnevni boravak, blagovaonicu, spavaću sobu i kupaonicu itd. Možete odabrati prema svojim zahtjevima i željama kako biste stvorili ekskluzivno idealno kućno okruženje za sebe. Apple House – kvaliteta življenja u najboljem izdanju! Apple House je posebno mjesto! Učini svoj dom sigurnijim i udobnijim postavljanjem kontejnera!Koristimo kontejnersku trgovinu koja uključuje sve strukturne komponente. Svi su prefabrikirani u standardnoj tvornici Odaberite odgovarajuću veličinu i konfiguraciju, možete brzo izgraditi životni prostor kako biste ispunili svoje zahtjeve. Na temelju zahtjeva klijenta i preferencija, različiti moduli se mogu kombinirati kako bi se stvorili različiti raspored prostorija kao što su kuhinja, dnevna soba ili spa Proces instalacije je jednostavan i jednostavan, a ne zahtijeva nikakva posebna tehnička znanja. Bilo da je to za vaš osobni prostor, privremenu kancelariju, skladištenje ili druge potrebe, naša prefabrikirana kuća za kontejnere dizajnirana je kako bi zadovoljila vaše potrebe. Kupite kontejnersku sobu danas i uživajte u nižoj cijeni i pristojnijoj usluzi. Složna kuća slijedi kontejnerski skladište koji se može rasporediti u skladu s vašim zahtjevima kako bi se povećala proizvodnja i vaš životni prostor učinio sigurnijim, stabilnijim i pouzdanijim. Soba se može rasporediti tako da može prilagoditi različitim zahtjevima, što znači da možete biti udobni bilo gdje i bilo kada. Brza isporuka! Prenosi i pakiranje su izuzetno brzi. Zapošljavamo stručnu ekipu za pakovanje prema vašim specifikacijama za pakovanje sklopne sobe tako da dobijete najkvalitetniji proizvod. Pratimo sve procese isporuke kako bismo bili sigurni da vaše stvari sigurno stignu do svoje destinacije. Najvažnije je da se sklopna soba lako instalira bez zavarivanja na licu mjesta i nudimo uputstva za instalaciju kako bi vaš proces instalacije bio brži i lakši. Ako slijedite upute lako je postaviti sklopljivu kuću. CDPH proizvodi i prodaje različite vrste modularnih kuća, Prefab kuća i Vilu kuća. Širok raspon proizvoda osigurava da možemo ponuditi odgovarajuće rješenje za svaki inženjerski tabornik.Spremište kontejnera
Prednosti našeg spremišta za kontejnere

Visokokvalitetni proizvodi za kupce na veliko

Uobičajeni problemi pri organizaciji kontejnera

Većinske cijene na najbolje proizvode za spremište kontejnera
Why choose CDPH
Spremište kontejnera?
Nova stvar prefabricirani kuća
Moderni stil apple kabina
Dobar kućni poslovnica
Visoka kvaliteta složiva kuća
Povezane kategorije proizvoda
Ne možete pronaći ono što tražite?
Zatražite ponudu sada
Kontaktirajte naše konsultante za dostupne proizvode.Kontaktirajte nas
27+ Godina Iskustva
Izgradnja inženjerskog tabora