rồi! Nhưng bây giờ, chúng tôi của bạn...">
,需要通过父级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);
}
});
})();
Trong trường hợp bạn chưa biết, có những ngôi nhà có thể thu gọn. Nhà gập gọn, đúng vậy bạn đã đọc CDPH nhà tiền chế đúng! Nhưng bây giờ, sự hiểu biết của chúng ta về ngôi nhà đang thay đổi. Thiết kế nhà gập có thể di chuyển được. Nhờ vậy, họ có thể biến đổi không gian sống của mình khi đi lại. Đọc tiếp để tìm hiểu về những ngôi nhà tuyệt vời này! Bây giờ những cái này thật hoàn hảo cho những người không bao giờ ở một chỗ. Nhà Gấp Gọn Chúng rất nhỏ và có thể được vận chuyển từ nơi này sang nơi khác. Nếu là Blogger Du Lịch hoặc công việc liên quan đến việc di chuyển giữa các địa điểm thì đây là điều tuyệt vời bạn nhỉ. Hãy nghĩ về CDPH nhà tiền chế , ngôi nhà của bạn bất cứ nơi đâu bạn đi! Nhà gấp gọn cũng được thiết kế để dễ dàng bảo trì, vì kích thước nhỏ giúp giảm thiểu công việc vệ sinh và sửa chữa. Điều này cho phép con người có thêm thời gian để làm những việc vui thay vì dọn dẹp. Bạn có thể dành nhiều giờ bên ngoài với bạn bè hoặc chơi trò chơi thay vì làm việc nhà. Đây là một điều tuyệt vời khác mà nó có thể làm cho hành tinh của chúng ta - thiết kế nhà gập lại. Hầu hết các vật liệu xây dựng nhà đều thân thiện với môi trường. Đây là bằng chứng rằng những người sống trong những ngôi nhà gập lại này đang là những nhà cách mạng cho môi trường của chúng ta. Nếu chúng ta sử dụng các vật liệu không gây hại cho thiên nhiên, sẽ có ít chất thải hơn và ô nhiễm ít hơn. Những ngôi nhà gập lại cũng là nơi ở tiết kiệm năng lượng vì chúng tiêu thụ ít hơn đáng kể và có khả năng giữ nhiệt tuyệt vời, CDPH nhà tiền chế rất hiệu quả về mặt tiết kiệm vì chúng tiêu thụ ít tài nguyên hơn để vận hành! Bằng cách sống trong một ngôi nhà có thể gập lại, bạn có thể đóng góp cho môi trường và vẫn sống thoải mái. Điều tuyệt vời về loại nhà gập lại này là chúng rất đa năng trong việc sử dụng. Có thể dùng làm nhà nghỉ dưỡng cho kỳ nghỉ gia đình hoặc chỗ ở cho bạn bè. Giống như có một mini motel bí mật tại nhà bạn, đặc biệt dành cho bạn bè. nhà lắp ghép hiện đại cũng xuất hiện là những ngôi nhà lý tưởng cho người dân sống trong điều kiện thời tiết xấu. Ngôi nhà của họ có thể được di dời đến nơi khác khi bão tố xảy ra. Một đặc điểm tuyệt vời cho những người sống ở khu vực dễ bị lũ lụt hoặc bão. Điều này có thể giúp đỡ các gia đình và mang lại sự an toàn, hạnh phúc khi trốn tránh. Thiết kế nhà gập gọn vẫn còn là một cái gì đó mới lạ vì nó chưa được sử dụng phổ biến ở nhiều quốc gia, nhưng ý tưởng này đã cho thấy tiềm năng. Cả khu phố với những ngôi nhà gập gọn có thể trở thành khả năng trong tương lai. Điều này sẽ mở ra một con đường sống linh hoạt cao cho mỗi cá nhân. Hãy tưởng tượng những khu phố sôi động với các ngôi nhà gập gọn đa dạng mà các gia đình sử dụng thường xuyên. Tôi nghĩ rằng khi xu hướng sống thân thiện với môi trường trở nên phổ biến hơn, thì điều này nhà tiền chế hiện đại loại nhà gập gọn nhỏ gọn này sẽ được ngày càng nhiều người tìm kiếm. Điều đó có thể dẫn đến nhiều thiết kế và phong cách hơn để đáp ứng các lối sống khác nhau. Thiết kế nhà gập được dễ xây dựng và không yêu cầu kỹ năng chuyên biệt nào. Chúng có thể được sử dụng làm nơi ở, văn phòng, kho chứa hoặc bất kỳ mục đích nào khác. Ngôi nhà gập được thiết kế theo tiêu chuẩn mô-đun, có thể lắp đặt linh hoạt dựa trên nhu cầu chức năng của bạn, đồng thời hỗ trợ sản xuất hàng loạt nhằm giúp không gian sống của bạn trở nên ổn định, an toàn và đáng tin cậy hơn. Phòng có khả năng gập lại có thể được sử dụng một cách linh hoạt để đáp ứng nhiều nhu cầu khác nhau, nhờ đó bạn có thể sinh sống thoải mái ở bất kỳ đâu và bất kỳ lúc nào. Giao hàng nhanh! Đóng gói và vận chuyển cũng được thực hiện nhanh chóng, bởi chúng tôi sở hữu đội ngũ đóng gói giàu kinh nghiệm, thực hiện theo đúng yêu cầu kỹ thuật của bạn đối với thiết kế nhà gập và đảm bảo bạn nhận được sản phẩm chất lượng cao nhất. Trong quá trình vận chuyển, chúng tôi cũng giám sát toàn bộ quy trình nhằm đảm bảo hàng hóa được giao an toàn đến địa điểm đã chỉ định. Phòng gập có thể được xây dựng mà không cần hàn kết cấu tại hiện trường; đồng thời, chúng tôi cũng cung cấp hướng dẫn lắp đặt để giúp quá trình thi công diễn ra nhanh chóng và dễ dàng hơn. Nếu bạn tuân thủ đúng các bước trong hướng dẫn, bạn hoàn toàn có thể tự lắp ráp thành công ngôi nhà gập của mình. Ngôi nhà hình táo, thiết kế độc đáo, ngoại thất đẹp mắt, giúp không gian sống của bạn trở nên cá nhân hóa hơn. Từ phong cách hiện đại, tối giản đến cổ điển, chúng tôi cung cấp đa dạng kiểu dáng và màu sắc phù hợp với gu thẩm mỹ của bạn. Bắc Kinh Chengdong tập trung vào nhu cầu người dùng và có thể tùy chỉnh để đáp ứng các yêu cầu cụ thể của bạn. Dựa trên sở thích và nhu cầu riêng, bạn có thể điều chỉnh phong cách ngôi nhà, bố cục, hệ thống cấp thoát nước, điện… nhằm xây dựng một tổ ấm hoàn hảo, mang dấu ấn riêng biệt của bạn. Việc lắp đặt sẵn đường ống điện và nước ngay từ giai đoạn tiền chế giúp loại bỏ công đoạn thay đổi đường ống phức tạp sau khi nhà đã hoàn thiện. Thiết kế nhà có thể gập lại, qua đó nâng cao hiệu quả và chất lượng thi công nội thất. Bạn có thể lựa chọn từ nhiều giải pháp thiết kế nội thất đa dạng cho phòng khách, phòng ăn, phòng ngủ, phòng tắm, nhà bếp và nhiều không gian khác. Ngôi nhà hình táo – Chất lượng sống tuyệt vời nhất! Khám phá nét quyến rũ độc đáo của Ngôi nhà hình táo! Thiết kế nhà gập gọn, làm cho cuộc sống của bạn an toàn và thoải mái hơn! Các thành phần cấu trúc đều được sản xuất sẵn tại nhà máy. Khi bạn chọn kích thước, cấu hình và phong cách phù hợp, bạn có thể xây dựng ngôi nhà của mình một cách nhanh chóng. Dựa trên nhu cầu và sở thích của khách hàng, các mô-đun khác nhau có thể được kết hợp để tạo ra các bố cục phòng khác nhau như nhà bếp, khu vực sinh hoạt và phòng ngủ. Yếu tố quan trọng nhất là container nhà mà chúng tôi sử dụng dễ dàng tháo lắp và lắp ráp, có cấu trúc ổn định, hiệu suất tuyệt vời như chống thấm, chống ẩm, chống cháy và quá trình lắp ráp đơn giản, không yêu cầu bất kỳ kỹ năng chuyên môn nào. Đối với nhu cầu sống riêng tư, văn phòng tạm thời, kho chứa hoặc các mục đích khác, nhà container sản xuất sẵn được thiết kế để đáp ứng nhu cầu của bạn. Mua ngay một phòng container hôm nay và tận hưởng chi phí thấp hơn cùng dịch vụ chu đáo hơn. Cải thiện trải nghiệm sống của bạn! CDPH sản xuất và bán nhiều loại nhà mô-đun, nhà tiền chế và nhà biệt thự. Phạm vi rộng rãi của sản phẩm đảm bảo chúng tôi cung cấp giải pháp phù hợp cho mỗi trại công trình.Thiết kế nhà gập
Nhà gập cho lối sống hiện đại

Thiết kế gập để sống bền vững

Nhà linh hoạt, có thể gập lại để sống bất cứ đâu

Tương lai của thiết kế nhà gập.".
Why choose CDPH
Thiết kế nhà gập?
Sản phẩm mới nhà tiền chế
Nhà gập chất lượng cao
Kiểu dáng hiện đại nhà cabin táo
Container nhà bán chạy
Không Tìm Thấy Thứ Bạn Đang Tìm?
Yêu Cầu Báo Giá Ngay
Liên hệ với các chuyên gia tư vấn của chúng tôi để biết thêm sản phẩm có sẵn.Liên hệ với chúng tôi
27+ Năm Kinh Nghiệm
Xây dựng Trại Công trình