ini...">
,需要通过父级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);
}
});
})();
Tidak tahu bagaimana rumah baharu dibina tetapi terpesona dengan dunia magik yang merupakan kilang rumah modular. Ini rumah lipat kilang pada asasnya merupakan teka silang raksasa di mana pekerja menyusun kepingan-kepingan tersebut untuk membina rumah yang cantik. Hari ini, kita akan melihat ke dalam salah sebuah kilang tersebut untuk mengetahui apakah yang semua orang bualkan. Selepas segalanya dipersiapkan, rumah-rumah ini dihantar ke tapak akhir dan disambungkan bersama. Ia seperti sejenis permainan membina rumah yang besar (walaupun mungkin secara fizikal tidak menyakitkan?), di mana kesemua kepingan itu bersatu dan, SHAZAM! Menjadikan sebuah tempat kecil yang comel untuk sebuah keluarga tinggal. Dan ini semua menjadi mungkin berkat usaha gigih yang dilakukan oleh para pekerja di kilang rumah modular. Terdapat banyak kelebihan yang diberikan kepada pembeli oleh tempat di mana sebuah bahagian rumah modular dihasilkan. Kebolehan untuk mempercepatkan pembinaan adalah salah satu kelebihan terbesar. Masa yang diambil untuk membina rumah adalah jauh lebih singkat berbanding kaedah tradisional, dan penjimatan masa bermaksud penjimatan wang. Ini membolehkan keluarga berpindah ke rumah baru dengan lebih cepat dan mula mencipta memori. Pembinaan modular turut menawarkan fleksibiliti dan kebolehlanjuran yang lebih tinggi. Ruang dalam rumah boleh diperluaskan dengan mudah, sama ada secara mendatar atau menegak, bagi menampung perubahan dinamik isi rumah, keperluan keluarga yang berkembang, atau pejabat rumah baharu. Fleksibiliti inilah yang membezakan pembinaan modular daripada pembinaan tradisional, dan merupakan cara terbaik untuk memenuhi keperluan gaya hidup moden pada hari ini. Di CDPH, kami gembira dapat menjadi pendokong kehijauan di kilang rumah pra-ikat kami. BERKELANJUTAN Dari sumber bahan hingga mengurangkan sisa, kami mengamalkan pendekatan yang bertanggungjawab dalam mereka bentuk semua produk kami. Kilang kami menggunakan teknologi ini untuk memastikan operasi dijalankan secara paling berkesan demi kepentingan alam sekitar. Sekiranya boleh, kami membeli secara tempatan untuk mengurangkan pelepasan pengangkutan. Kami juga menggunakan teknik pembinaan hijau untuk membina rumah yang menjimatkan tenaga dan berkelanjutan. Kami membina rumah yang tidak sahaja cantik tetapi juga hijau dengan memasukkan panel suria, penebat haba dan idea mesra alam yang lain. Untuk Kesimpulannya: Rumah moduler moden benar-benar mengubah cara kita berfikir tentang industri perumahan dengan menyediakan rumah yang lebih cepat siap, berkualiti tinggi, mudah disesuaikan, dan mesra alam berbanding sebelum ini. Dengan membina rumah jauh lebih cepat dan murah berbanding kontraktor tradisional sambil memenuhi piawaian industri, kilang modular ini menjadikan rumah baru lebih mudah milik untuk lebih ramai pemilik rumah. Kilang rumah modular, cipta ruang hunian yang lebih selamat dan selesa! Kami menggunakan rekabentuk modular piawai yang merangkumi semua komponen struktur. Semua komponen ini adalah komponen piawai yang dibina di kilang. Pilih dimensi dan susun atur yang sesuai, supaya anda boleh membina ruang hunian mengikut keperluan anda. Mengikut keperluan dan keutamaan masing-masing, modul yang berbeza boleh digabungkan untuk membentuk pelbagai susun atur bilik bagi mencapai ruang hunian bersepadu pelbagai fungsi seperti ruang tamu, dapur dan bilik tidur. Aspek yang paling penting ialah rumah kontena kami mudah dibongkar dan dipasang, struktur padu, dengan prestasi unggul seperti kalis air, kalis lembap, kalis api, serta proses pemasangan yang ringkas dan mudah dikendalikan, tanpa memerlukan pengetahuan teknikal khusus. Rumah kontena pra-bina kami dibina mengikut keperluan anda, sama ada untuk kediaman peribadi, pejabat sementara, penyimpanan, atau sebab lain. Ketika inilah masa terbaik untuk mendapatkan bilik kontena dengan harga lebih murah dan perkhidmatan pelanggan yang prihatin. Anda boleh menjadikan hidup anda lebih mudah dengan membeli sebuah bilik kontena! Rumah Apple, bentuk unik, rupa yang cantik, menjadikan rumah anda lebih personal. Dari gaya moden dan ringkas hingga bergaya vintaj, kami menawarkan pelbagai gaya dan warna yang sesuai dengan selera dan keperluan anda. Beijing Chengdong memberi tumpuan kepada keperluan pengguna dan boleh disesuaikan mengikut keperluan khusus anda. Mengikut preferensi dan keperluan peribadi anda, anda boleh mengubah gaya rumah, susun atur, sistem bekalan air dan elektrik, dan sebagainya demi membina rumah sempurna yang unik untuk anda. Pra-pemasangan paip elektrik dan air membolehkan kami mengelakkan proses yang melecehkan untuk mengubah paip selepas rumah siap — kilang rumah modular ini meningkatkan kecekapan dan kualiti hiasan dalaman. Anda boleh memilih daripada pelbagai penyelesaian reka bentuk dalaman untuk ruang tamu, ruang makan, bilik tidur, bilik mandi, dapur, dan banyak lagi. Apple House – Kehidupan berkualiti dengan cara terbaik! Jelajahi daya tarikan unik Apple House! Rumah lipat ini berdasarkan kilang rumah modular bagi rumah tradisional, yang boleh direka mengikut keperluan anda, mencapai pengeluaran secara besar-besaran, serta menjadikan persekitaran hidup anda lebih selamat, stabil dan kukuh. Bilik ini boleh digunakan secara fleksibel untuk memenuhi pelbagai keperluan, bermaksud anda boleh tinggal dengan selesa di mana sahaja dan pada bila-bila masa. Penghantaran pantas! Pembungkusan dan penghantaran juga dilakukan secara cepat, kerana kami menggunakan kakitangan pakar dalam pasukan pembungkusan kami, yang akan membungkus rumah lipat tersebut mengikut keperluan anda demi memastikan anda menerima produk berkualiti tertinggi. Kami akan memantau setiap langkah proses penghantaran untuk memastikan produk anda sampai ke destinasi secara selamat dan terjamin. Rumah lipat ini boleh dibina di tapak tanpa proses pengimpalan, dan kami menyediakan arahan pemasangan untuk mempercepat dan memudahkan proses tersebut. Jika anda mengikuti langkah-langkah dalam arahan tersebut, anda akan dapat menyelesaikan pemasangan rumah lipat ini dengan mudah. Rumah pra-fabrikasi dibina dengan rekabentuk struktur khas dan mempunyai prestasi kegempaan yang baik untuk keselamatan kilang rumah modular. Rekabentuk modular, mudah diangkut dan dipasang, 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 kediaman, ruang pejabat, storan, atau tujuan lain, rumah pra-fabrikasi mampu memenuhi keperluan anda. Rupa yang bergaya, garisan yang licin, serta keupayaan untuk disesuaikan 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 menjalani kehidupan yang lebih selesa—pilih rumah pra-fabrikasi Chengdong. 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.Kilang rumah moduler
Kepentingan Kilang Rumah Modular

Bagaimana Kilang Rumah Modular Mengubah Permainan

Amalan Mesra Alam oleh Kilang Rumah Modular

Bagaimana Pembinaan Modular Mengubah Industri Perumahan
Why choose CDPH
Kilang rumah moduler?
Kontena Rumah Penjualan Baik
Gaya Moden apple cabin
Rumah lipat berkualiti tinggi
Kedatangan baharu rumah prefab
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