rumah pra-bina kecil yang menarik dari CDPH...">
,需要通过父级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);
}
});
})();
KLIK BUTANG UNTUK MASUK KE KONTES Adakah anda sedang mencari secebis rumah yang selesa tanpa meruntuhkan corak? Masuk kontes hebat CDPH rumah kecil pra-bina ! Reka Bentuk Rumah Kecil untuk Mereka yang Menghargai Kualiti, Ketermampuan, & Kelestarian Dari perspektif borong, mari lihat apa yang ditawarkan oleh CDPH. Menawarkan pelbagai rumah pra-bina kecil pada harga yang membuat celengan anda "menguiang", CDPH menyediakan kepakaran domain yang merangkumi beberapa bidang fungsional dalam ruang rumah kontena pra-bina yang semakin berkembang. Dari bilik tidur yang selesa hingga dapur dan bilik mandi yang berfungsi, penginapan kami mempunyai segala-galanya yang anda perlukan untuk hidup. Dan yang terbaik? Anda boleh mendapatkan semua ini pada harga yang mampu milik tanpa rasa seperti membazir wang! Kami di CDPH tidak percaya bahawa kualiti harus dikorbankan walaupun untuk rumah kecil. Oleh sebab itu, rumah pra-bina kami dilengkapi dengan bahan-bahan terbaik seperti permaidani dan kerja tangan yang berkualiti tinggi. Anda boleh mengharapkan rumah CDPH tahan lama berkat dinding yang kukuh dan lantai yang kuat. Tambahan pula, dengan komitmen kami terhadap kesempurnaan dan perhatian terhadap butiran, anda boleh yakin akan menerima produk yang unggul. CDPH memahami bahawa tidak semua rumah adalah sama, justeru kami menawarkan rekabentuk yang boleh disesuaikan untuk pembeli borong kami. Sama ada anda mahukan ruang tamu yang besar, ruang storan tambahan, atau susun atur yang sempurna, kami menyediakan segala-galanya mengikut keperluan anda. Kami mempunyai pasukan pereka pakar yang akan bekerjasama dengan anda dan memberi sepenuh usaha mereka untuk mencipta rumah yang lengkap dan bersesuaian dengan gaya serta standard hidup anda. CDPH sedia menyesuaikan rumah idaman anda mengikut citarasa anda. Di CDPH, planet ini penting bagi kami, itulah sebabnya semua rumah kecil kami adalah mesra alam dan mampan. Kami menggunakan peralatan yang cekap tenaga dan bahan kitar semula dalam rumah kami untuk memastikan impak terhadap alam sekitar adalah minimum. Dengan cara ini, anda boleh menikmati rumah baharu anda sambil turut menyumbang sedikit tambahan untuk alam sekitar. Tempat anda tinggal bermakna CDPH. Memandangkan kami tahu anda mahu mendapatkan rumah baharu anda dengan cepat, CDPH menyediakan kaedah penghantaran keutamaan untuk pembeli borong kami. Selepas pesanan diproses, hanya perlu beberapa minggu sahaja untuk rumah anda dihantar dan dipasang siap sedia untuk kehidupan baharu anda. Jadi, anda boleh menikmati keselesaan CDPH dengan gaya lebih awal. rumah pra-binaan kecil, cipta ruang hidup yang lebih selamat dan selesa! Kami menggunakan rekabentuk modular piawai yang merangkumi semua komponen struktur. Semua komponen ini dibina di kilang mengikut piawaian. Pilih dimensi dan susun atur yang sesuai, supaya anda boleh membina ruang hidup anda mengikut keperluan anda. Mengikut keperluan dan preferensi mereka, modul-modul berbeza boleh digabungkan untuk membentuk pelbagai susun atur bilik bagi mencapai ruang hidup bersepadu pelbagai fungsi seperti ruang tamu, dapur dan bilik tidur. Aspek yang paling penting ialah rumah kontena kami mudah dibongkar dan dipasang semula dengan struktur yang kukuh, serta mempunyai prestasi cemerlang seperti kalis air, kalis lembap, kalis api, dan proses pemasangan yang ringkas serta mudah dikendalikan tanpa memerlukan pengetahuan teknikal khusus. Rumah kontena pra-binaan kami dibina mengikut keperluan anda, sama ada untuk kediaman peribadi, pejabat untuk kegunaan sementara, storan, atau sebab-sebab lain. Sekaranglah masanya untuk mendapatkan bilik kontena dan menikmati harga yang lebih murah serta perkhidmatan pelanggan yang penuh perhatian. Anda boleh memudahkan kehidupan anda dengan membeli bilik kontena! Rumah lipat direka menggunakan sistem modular yang boleh dikonfigurasikan mengikut keperluan khusus rumah anda. Ini membolehkan pembinaan rumah pra-kilang berukuran kecil serta menjadikan rumah anda lebih selamat, stabil dan kukuh. Bilik ini boleh digabungkan dengan bilik-bilik lain untuk memenuhi pelbagai keperluan, bermaksud anda boleh tinggal secara selesa di mana sahaja dan pada bila-bila masa. Penghantaran pantas! Kami juga menyediakan perkhidmatan pembungkusan dan penghantaran yang cekap. Pasukan pakar pembungkusan kami akan membungkus bilik lipat anda mengikut keperluan pelanggan. Kami akan memantau setiap langkah proses penghantaran untuk memastikan barang-barang anda sampai ke destinasi dengan selamat. Bahagian terbaiknya ialah bilik lipat ini mudah dibina tanpa pengelasan di tapak, dan kami menyediakan garis panduan pemasangan untuk mempercepat dan memudahkan proses pemasangan anda. Jika anda mematuhi semua langkah dalam garis panduan ini dan mengikuti arahan yang diberikan, anda akan dapat menyelesaikan pembinaan rumah lipat anda. Rumah pra-fabrikasi dibina dengan rekabentuk struktur khas dan mempunyai prestasi seismik yang baik untuk keselamatan rumah pra-fabrikasi berskala kecil. Rekabentuk modular, mudah diangkut dan dipasang, serta boleh disesuaikan mengikut preferensi peribadi anda dari segi pelbagai gaya dan jenis bilik. Semua elemen diperbuat daripada bahan pra-fabrikasi dan mudah dirakit tanpa memerlukan kemahiran khusus. Sama ada digunakan sebagai kawasan tinggal, ruang pejabat, storan, atau tujuan lain, rumah pra-fabrikasi mampu memenuhi keperluan anda. Rupa yang bergaya, garis-garis yang licin, serta kemudahan penyesuaian mengikut preferensi peribadi membolehkan anda mencipta ruang hidup yang unik. Yang paling penting, rumah pra-fabrikasi tidak memerlukan pengelasan di tapak, dan kami juga menyediakan arahan pemasangan untuk memudahkan dan mempercepat proses pemasangan. Manfaatkan kelebihan kehidupan yang lebih selesa—pilih rumah pra-fabrikasi Chengdong. Kabin Apple, rumah pra-bina kecil, rupa yang indah, menjadikan rumah anda lebih personal. Dari gaya moden asas hingga retro, kami menawarkan pelbagai gaya dan warna yang sesuai dengan selera dan keperluan anda. Beijing Chengdong berfokus kepada keperluan pengguna dan boleh disesuaikan mengikut kehendak anda. Mengikut keinginan dan preferensi anda, anda boleh mengubah reka bentuk rumah, tata letak, sistem air dan elektrik, dan sebagainya, untuk mencipta rumah individu yang sempurna buat anda. Pra-pemasangan paip elektrik dan air membolehkan kami mengelakkan proses penataan semula paip yang mengambil masa setelah rumah dihias, seterusnya meningkatkan keberkesanan dan kualiti hiasan. Kami menawarkan pelbagai penyelesaian tata letak dalaman, termasuk ruang tamu atau kawasan makan, bilik tidur, dapur, bilik air dan sebagainya. Anda boleh memilih mengikut keperluan dan preferensi anda demi mereka bentuk rumah yang sempurna buat anda. Kehidupan berkualiti bermula dari Rumah Apple! Datang dan alami daya tarikan unik Rumah Apple! CDPH memproduksi dan menjual pelbagai jenis rumah modul, rumah prefabrikasi dan rumah villa. Julat produk yang luas memastikan kami menyediakan penyelesaian yang sesuai untuk setiap kem kejuruteraan.rumah kecil pra-bina
Bahan Berkualiti Tinggi dan Kerja Tangan yang Teliti untuk Pembeli Borong

Reka bentuk boleh disesuaikan untuk memenuhi keperluan pembeli borong

Rumah pra-bina kecil mesra alam dan mampan untuk pembelian secara borong

Penghantaran pantas dan mudah untuk pembeli borong yang berminat terhadap rumah pra-bina kecil
Why choose CDPH
rumah kecil pra-bina?
Kontena Rumah Penjualan Baik
Rumah lipat berkualiti tinggi
Kedatangan baharu rumah prefab
Gaya Moden apple cabin
Tidak jumpa apa yang anda cari?
Minta Sebut Harga Sekarang
Hubungi pakar kami untuk mendapatkan lebih banyak produk yang tersedia.Hubungi Kami
27+ Tahun Pengalaman
Pembinaan Kem Kejuruteraan