, nes jie yra patrauklaus išvaizdos ...">
,需要通过父级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);
}
});
})();
Šiandien namai iš konteinerių gauna daug paskaitų. Žmonės myli CDPH sudedamasis konteinerio namas nes jie yra gražūs ir daugeliui lengvai sudėti. Todėl šiame straipsnyje išsamesniai aptarsime konteinerinius namus ir kodėl daugelis žmonių yra atrakciją gyventi j从中. Pradėdamas, konteineriniai namai būsto pramone yra paprastai sukonstruoti iš senų ar naudotų prekių konteinerių. Jei iš šių konteinerių iškirsi langus ir duris, jį galima paversti namu. Tai jų daro idealiais greitesniam ir spartesniam naudojimui statydamiesi naują namą. Konteineriai, kurie buvo naudojami kaip medžiagos, yra pakankamai stipriečiai ir saugūs, todėl turėtumėte jaučiasi taip pat, kaip ir namuose. Tai vienintelis priežastis, kodėl žmonės myli konteinerinius namus dėl jų stiprumo ir ilgalaikumo. Jie taip pat puikiai tinka tiems, kurie nereikalauja daug vietos. Jie labai geresni mažam gyvenimui su tik tuo erdvės, ką tikrai reikia. Taip sumažinamas surinkimas ir išvengiamas netvarkingumas. Su papildomu erdvės apdorojimu CDPH sudedamasis konteinerio namas nėra visada visiškai netvarkingas ir tai tiesiog padeda mums būti tvaresniems. Aiškus erdvės, dabar, man skamba labai gera; iš šio saulingo gyvenimo. Iš tiesų, jie atrodo kaip dideli, sunkūs metaliniai dėžutės, kurias niekas nesuprastų kaip atrakcinę. Bet kartu, reikia tik šiek tiek imitacijos ir kūrybingumo architektūros srityje, kad šias geležies dėžutes paverstume gražiais namais. Užbaikite juos, pridėkite išorinį izoliaciją ir langus - daug durų. Ką keletas žmonių nesupranta, yra tas, kad CDPH išplėstinas konteineris namuose iš esmės baigiasi itin moderniai, ir bendrai jie yra gana gražūs. Namai iš konteinerių yra tokie stilingi, nes jie tikrai gali būti sukurti kaip bet kas ir padaryti asmenini. Nepaisant to, kiek jums reikia langų ir durų, kur jie turėtų būti ar kokių tipų podučių/arščių yra prieinama. Įdėdamas savo pečius į CDPH išplėstinas konteineris namuose tikrai suteikia vietos papildomą charakterį, kuris kyla iš jūsų. Kai jūsų namas atspindi tai, kaip jūs dresuojatės natūraliai, tai tiesiog jaučiasi saugesniu ir linksmesniu vieta kiekvieno dienos širdyje. Dar vienas labai stylingas būdas išnaudoti prekybinės sandėlio konteinerius yra naudoti juos kaip namus. Geras pavyzdys, kaip atrodytų Namai iš Sandėlio Konteinerių CDPH išplėstinis konteinerio namo kaina . Tai išvalyti ir atnaujinti konteineriai, praversę į namus. Jie taip pat gali kainuoti mažiau nei nauji konteineriai, o tai galėtų padėti jums užtaisyti pinigus, kad galėtumėte pradėti savo sapnuojamąjį namą. Be to, tai taip pat sumažina atliekas, nes konteineriai yra perdirbami. Skleidžiamasis namas sukurtas naudojant modulinę sistemą, kurią galima konfigūruoti pagal jūsų namų specifinius reikalavimus. Tai leidžia suprojektuoti konteinerių namus ir padaryti jūsų namus saugesnius, stabileresnius ir patikimesnius. Patalpa gali būti sujungta su kitomis patalpomis, kad būtų patenkinti įvairūs reikalavimai, todėl galėsite patogiai gyventi bet kur ir bet kada. Greita pristatymo paslauga! Taip pat teikiame greitą pakavimo ir pristatymo paslaugą. Mūsų patyrę pakavimo specialistai pakuos jūsų skleidžiamąją patalpą pagal kliento reikalavimus. Visą pristatymo proceso eigą stebėsime, kad užtikrintume, jog jūsų prekės saugiai pasiektų paskirties vietą. Geriausia yra tai, kad skleidžiamąją patalpą galima lengvai surinkti tiesiog vietoje be suvirinimo, o mes pateikiame montavimo instrukcijas, kurios padarys jūsų montavimo procesą greitesnį ir paprastesnį. Jei tiksliai laikysitės visų instrukcijose nurodytų žingsnių, galėsite sėkmingai baigti savo skleidžiamojo namo statybą. Obuolių namukas, unikali forma, gražus išvaizdos įspūdis – padarykite savo namus dar asmeniškesnius. Turime įvairių stilių ir spalvų variantų, kurie atitinka jūsų asmeninius skonius – nuo paprastų šiuolaikinių iki tradicinių. „Beijing Chengdong“ specializuojasi konteinerinės namų projektavimo srityje ir gali pasiūlyti individualiai pritaikytus sprendimus pagal jūsų poreikius. Kadangi kiekvienas žmogus yra unikalus, galite pasirinkti namo projektą, planuotę, vandens bei elektros sistemą ir kt., kad sukurtumėte idealų, išsklitančią namų erdvę tik jums. Elektros ir vandens tiekimo sistemos buvo suprojektuotos ir įrengtos dar prieš pradedant statybas, todėl vengiama laiko švaistymo, reikalingo vėlesniam vandens ir elektros laidų perdėstymui po apdailos darbų, o tai padidina apdailos efektyvumą ir kokybę. Gyvenamajai erdvei, valgomajai, miegamajai, virtuvei ir daugeliui kitų patalpų galite pasirinkti įvairiausius vidaus dizaino sprendimus. Aukštos kokybės gyvenimas prasideda nuo Obuolių namuko! Obuolių namukas – tai unikali erdvė! Prefabrikuotas namas pastatytas specialia konstrukcine sistema ir turi gerą seismologinę atsparumą, užtikrinančią saugumą. Modulinė konstrukcija leidžia lengvai perkelti ir įrengti namą, o konteinerinių namų projektavimas gali būti pritaikytas pagal jūsų asmenines nuostatas – skirtingus stilius, kambarių tipus. Visi elementai pagaminti iš prefabrikatuotų medžiagų, todėl juos lengva montuoti be specialių įgūdžių. Nepriklausomai nuo to, ar namas skirtas biurui, gyvenimui, sandėliavimui ar kitiems tikslams, prefabrikatuotas namas patenkina jūsų poreikius. Stilingas išvaizdos, glotnios linijos ir galimybė pritaikyti pagal individualius pageidavimus leidžia sukurti unikalų gyvenamąjį erdvę. Geriausia iš viso – prefabrikatuotų namų montavimui statybvietėje nereikia suvirinti, o mes pateikiame aiškias montavimo instrukcijas, kad procesas būtų paprastesnis ir greitesnis. Pradėkite naudotis patogesnio gyvenimo privalumais su Chengdong prefabrikuotais namais. Chengdong prefabrikuoti namai. Padarykite savo namus saugesnius ir patogesnius įrengdami konteinerius! Mes naudojame konteinerinių namų projektavimą, kuris apima visus konstrukcinius elementus. Visi jie yra pramoniniu būdu gaminami gamykloje pagal standartus. Pasirinkę tinkamą dydį ir konfigūraciją, galėsite greitai pastatyti gyvenamąją erdvę, atitinkančią jūsų reikalavimus. Remiantis kliento poreikiais ir pageidavimais, įvairūs moduliai gali būti sujungti, kad būtų sukurtos skirtingos patalpų išdėstymo schemos, pvz., virtuvės, svetainės ar miegamojo. Mūsų konteineriniame name yra puikūs privalumai: jis yra vandeniui nepraleidžiamas, drėgmei atsparus, korozijai atsparus, ugniai atsparus ir dar kartą – korozijai atsparus. Įrengimo procesas yra paprastas ir lengvas, specialių techninių žinių nereikia. Ar tai būtų jūsų asmeninė erdvė, laikinoji biuro patalpa, sandėliavimo patalpa ar kitos reikmės – mūsų pramoniniu būdu gaminami konteineriniai namai sukurti tam, kad atitiktų jūsų poreikius. Įsigykite konteinerinę patalpą jau šiandien ir pasinaudokite mažesnėmis kainomis bei mandagesne paslauga – padarykite savo gyvenimą malonesnį! CDPH gamina ir parduoda įvairius moduliinius namus, prefabrikatus ir vilios namus. Platus produktų spektras leidžia mums siūlyti tinkamą sprendimą kiekvienam inžinerijos kampei.Konteinerinių namų dizainas
Maksimizuojant mažą gyvenimą

Pervertiavimas: prekybos konteineriai taps švelniosiomis, šiuolaikinėmis namų versijomis

Asmeninis dizainas optimaliam komfortui

Statyba naudojant atnaujintus prekybos konteinerius
Why choose CDPH
Konteinerinių namų dizainas?
Aukštos kokybės sudedamasis namas
Suaugių stilius Apple kabina
Nauji prieinami prefabrikatuoti namai
Gerai pardavinė konteinerio namų
Susijusios prekių kategorijos
Nerandate to, ko ieškote?
Prašyti pasiūlymo dabar
Susisiekite su mūsų konsultantais dėl papildomų prekių.Susisiekite
27+ metų patirties
Inžinerijos kampų statyba