, ia...">
,需要通过父级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);
}
});
})();
Membangunkan sebuah rumah dengan CDPH mungkin merupakan satu tugas yang mencabar tetapi dengan rumah Kontena , ia menjadi menyeronokkan dan mudah. Dan terdapat sifat ketahanan pada rumah-rumah ini, yang dibina terutamanya daripada bekas logam besar, yang boleh menjadi kukuh dan mesra alam. Lihat beberapa reka bentuk paling cemerlang untuk hidup di tempat kecil — pelan lantai yang mampan, rumah pereka yang murah dan bergaya bermakna anda boleh tinggal di rumah idaman tanpa perlu membayar harga yang setanding, dan bangunan modular yang direka untuk kehidupan moden, namun cantik dalam menahan sebarang jenis persekitaran, semuanya merupakan sebahagian daripada pelan rumah kontainer. Rahsia dalam merekabentuk ruang tamu yang kecil adalah dengan bersikap kreatif. Pilihan terbuka luas dengan rumah kontena. Perabot pelbagai fungsi dan pengoptimuman ruang pada dinding anda hanyalah beberapa cara untuk memaksimumkan ruang kecil. CDPH menyediakan pelan lantai rumah kontena supaya anda dapat menggunakan setiap inci ruang anda. Penyelesaian kreatif untuk memaksimumkan ruang hidup yang kecil memberikan suasana yang cukup menarik sehingga jika anda memiliki sofa yang selesa dan mangkuk popcorn, anda langsung tidak akan merindui ruang tambahan. Hidup secara mampan adalah sesuatu yang perlu kita semua lakukan demi masa depan bumi kita. Rumah kontainer merupakan satu cara yang sangat baik untuk mengurangkan kesan terhadap alam sekitar dan kini semakin popular. Pelan lantai rumah kontainer CDPH direka bentuk untuk kelestarian. Rumah-rumah ini juga cekap tenaga, kerana cahaya semula jadi dan angin digunakan untuk memaksimumkan pencahayaan siang hari serta mengurangkan penggunaan lampu buatan dan pendingin hawa. Reka bentuk bilik yang luas Rumah kontainer mempunyai reka bentuk bilik yang fleksibel dan boleh dikembangkan, selain mudah diubah suai mengikut pelbagai keadaan cuaca. Rumah boleh menjadi mahal untuk dibina — tetapi tidak semua daripadanya. Tidak perlu mengorbankan estetika ketika tinggal di rumah kontainer. Pelan lantai rumah kontainer CDPH adalah mampu milik tanpa mengorbankan kualiti dan reka bentuk. Homestead boleh diperibadikan mengikut keperluan dan keinginan pemilik rumah, dan oleh itu telah menjadi pilihan yang modenis dan bijak dalam kalangan ramai pemilik rumah. Rumah kontainer juga sangat modular. Rumah dibina daripada kontainer individu yang boleh ditindih dan ditambah dalam pelbagai konfigurasi untuk mencipta ruang hidup yang berasingan. Pelan lantai Rumah Kontainer CDPH direka secara modular, menjadikannya mudah dikonfigurasikan mengikut keperluan anda. Jika anda memerlukan bilik tidur tambahan, pejabat rumah, atau malah rumah tetamu, rumah kontainer direka khas untuk memenuhi keperluan yang sentiasa berubah. Oleh sebab itulah mereka semakin popular dalam rumah moden. Setiap keluarga adalah unik, dengan cara hidupnya yang tersendiri. CDPH mengetahui bahawa setiap keluarga adalah unik, maka semua pelan lantai rumah kontainer mereka adalah sepenuhnya fleksibel. Daripada jumlah bilik tidur hinggalah kepada lokasi dapur dan ruang tamu, pemilik boleh membina rumah kontainer yang sesuai dengan kehidupan harian mereka. Sama ada anda merupakan keluarga kecil atau pasangan yang tidak mahu dibebani dengan ruang tambahan dan penyelenggaraan yang datang bersamanya, penghunian kontainer boleh menjadi pilihan yang sempurna buat anda. Rumah lipat mengikuti gaya modular rumah tradisional, yang boleh dikonfigurasikan mengikut keperluan anda untuk mencapai pengeluaran secara besar-besaran serta menjadikan persekitaran hidup anda lebih stabil, selamat dan terjamin. Bilik-bilik ini boleh digabungkan secara fleksibel untuk memenuhi pelbagai keperluan, membolehkan anda menetap di dalam pelan lantai rumah kontena di mana sahaja dan bila sahaja. Penghantaran pantas! Pembungkusan dan penghantaran juga dilakukan secara cepat; kami menggunakan pasukan pembungkusan profesional yang akan membungkus bilik lipat mengikut spesifikasi anda bagi memastikan anda menerima produk berkualiti terbaik. Kami akan memantau keseluruhan proses penghantaran untuk memastikan barang-barang anda tiba di destinasi dengan selamat dan terjamin. Bilik lipat boleh dipasang tanpa perlu mengimpal strukturnya di tapak, dan kami menyediakan garis panduan pemasangan yang akan menjadikan proses tersebut lebih cepat dan mudah. Selagi anda mengikuti semua langkah dalam garis panduan tersebut, pemasangan rumah lipat ini akan menjadi mudah untuk diselesaikan. Kabin Apple, bentuk unik, rupa yang cantik, menjadikan rumah anda lebih personal. Dari gaya moden asas hingga gaya vintaj, kami menyediakan pelbagai pilihan gaya dan warna yang dapat memenuhi citarasa anda. Beijing Chengdong memberi tumpuan kepada kehendak pengguna, yang boleh disesuaikan mengikut keutamaan anda. Mengikut keinginan dan citarasa sendiri, anda boleh mengubah suai gaya rumah, pelan lantai rumah kontena, susun atur, paip air dan elektrik, dan lain-lain untuk mencipta rumah idaman yang sempurna buat anda. Pra-pemasangan paip elektrik dan air membantu kita mengelakkan proses panjang untuk menyusun semula paip selepas siap didekorasi, yang meningkatkan kecekapan dan kualiti kerja dekorasi. Anda boleh memilih daripada pelbagai penyelesaian reka bentuk dalaman untuk kawasan tempat tinggal, kawasan makan, bilik tidur, bilik mandi serta dapur-dapur dan bilik mandi. Kehidupan berkualiti tinggi, di Rumah Apple! Datang dan alami daya tarikan unik Rumah Apple! Rumah kontena, jamin keselamatan anda dan buat kehidupan anda lebih selesa! Kami menggunakan rekabentuk modular piawai, semua komponen struktur adalah komponen pelan lantai rumah kontena dan tersedia dalam dimensi serta susun atur yang betul, supaya anda boleh dengan mudah membina ruang hidup yang sesuai dengan keperluan anda. Bergantung kepada keperluan dan preferensi pelanggan, modul-modul yang berbeza boleh digabungkan untuk mencipta pelbagai susun atur bilik seperti dapur, ruang tamu dan bilik tidur. Perkara paling penting yang perlu diperhatikan ialah rumah kontena yang kami gunakan mudah dibongkar dan dipasang semula dengan struktur yang kukuh, serta mempunyai prestasi cemerlang seperti kalis air, tahan kakisan, anti-kakisan dan perlindungan terhadap api; proses pemasangan juga mudah dan ringkas untuk dikendalikan, tanpa memerlukan kepakaran teknikal khusus. Sama ada untuk kegunaan peribadi, penyimpanan, pejabat sementara atau keperluan lain, rumah kontena pra-cekup kami direka khas untuk memenuhi keperluan anda. Inilah masa yang paling sesuai untuk mendapatkan bilik kontena dan menikmati harga yang lebih berpatutan serta perkhidmatan pelanggan yang penuh perhatian. Tingkatkan kualiti kehidupan anda dengan membeli ruang kontena! Rumah pra-dibina ini mudah dipasang dan tidak memerlukan sebarang pengetahuan khas. Rumah-rumah ini boleh digunakan sebagai pelan lantai rumah kontena, storan pejabat, atau untuk sebarang tujuan lain. 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.Pelan lantai rumah kontainer
Kehidupan mampan dengan pelan lantai yang pelbagai

Penyelesaian perumahan yang berkesan dari segi kos dan bergaya

Bangunan modular untuk kehidupan moden

Susun atur boleh suai untuk pengaturan hidup yang unik
Why choose CDPH
Pelan lantai rumah kontainer?
Rumah lipat berkualiti tinggi
Gaya Moden apple cabin
Kontena Rumah Penjualan Baik
Kedatangan baharu rumah prefab
Kategori produk berkaitan
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