ها ل...">
,需要通过父级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);
}
});
})();
چقدر از خانههای کانتینر حمل و نقل شنیدهاید؟ خانه کانتینر یک خانه جالب است که با کانتینر ساخته شده است. این خانهها خانه کانتینر حاویههای فلزی بزرگی هستند که کالاها ممکن است با کشتی و ریل ارسال شوند. اخیراً، شهرت آنها افزایش یافته است، زیرا هزینه ساخت آنها ممکن است کمتر از یک خانه معمولی باشد. با این حال، ساخت یک خانه کانتینر به اندازهای نخواهد بود که در ابتدا به نظر میرسد. عوامل زیادی در هزینه کلی ساخت خانه کانتینر شما نقش دارند. پس، برای مثال، شما میخواهید خانهی خود را به چه جهتی طراحی کنید؟ آیا میپسندید تعداد زیادی اتاق داشته باشد یا کمتر؟ مثلاً، چه ویژگیهایی میخواهید شامل شود؛ آیا یک آشپزخانه بزرگ یا یک حمام زیبا؟ چقدر میخواهید دخالت داشته باشید یا در غیر این صورت، آیا مزایایی برای استخدام یک شرکت دیگر وجود دارد؟ هر یک از این انتخابات بر نقطه قیمتی که خانه کانتینر شما کامل میشود، تأثیر خواهد گذاشت. تصمیمگیری اینکه آیا یک خانه کانتینر ارزانتر از یک خانه معمولی است بسیار به اینکه شما در سبک زندگی چه چیزی جستجو میکنید بستگی دارد. هزینههای اولیه برای خانههای کانتینر ممکن است کمتر باشد، اما این خانهها معمولاً نسبت به یک خانه سنتی پایداری کمتری دارند. به عنوان مثال، آنها ممکن است در طوفانها یا فراخوراکندههای شدید امنیت کافی را نداشته باشند که این موضوع بسته به محل زندگی شما مهم است. در ادامه چند نکته مهم برای صرفهجویی در هزینه خانه کانتینر اگر قصد ساخت آن را خودتان دارید ارائه میدهیم. ابتدا میتوانید از مصالح بازیافتی یا بازیابیشده مانند چوب قدیمی یا فلز استفاده کنید که میتواند در نگهداری از هزینهها کمک کند. مدیریت غیراقتصادی نه تنها هزینههای شما را کاهش میدهد بلکه اگر از بافت و کتکپاره استفاده کنید، از لحاظ زبالهها هم حکیمتآمیز است. گزینه دیگر این است که میتوانید یک سازنده تخصصی که در ساخت خانههای کانتینر تجربه دارد استخدام کنید. CDPH خانه کانتینر تاشو باید درک کاملی از آن داشته باشد و میتواند در بهرهبرداری از بهترین تخفیفها برای مواد و همچنین نیروی کاری کمک شما کند. برنامهریزی پیشرفته و دقیق ایتینرری دیگر یک نکته ضروری است که باید در نظر داشته باشید. نشسته و واقعاً فکر کنید که چه چیزی را در خانهی خود میخواهید. CDPH خانه کانتینر قابل جمع شدن میتواند گرانتر شود هر چه ویژگیها و تسهیلات بیشتری اضافه میکنید. بنابراین، باید بدانید که چه چیزهایی واقعاً لازم دارید و کجا میتوانید با آنها کار کنید. در این فرآیند، قادر خواهید بود بودجهای تنظیم کنید و در حال ساخت خانه کانتینر خود، به آن پایبند باشید. به دلایل مختلف، خانههای کانتینر میتوانند گزینهای کم هزینهتر نسبت به مسکن سنتی باشند. ابتدا، معمولاً ارزانتر هستند. CDPH خانه پیش ساخته کانتینری همچنین، سبز هستند زیرا کانتینرها را مجدد استفاده میکنند و از این طریق زباله و آلودگی را کاهش میدهند. علاوه بر این، خانههای ماژولی مثل کانتینرهای حمل و نقل کاملاً شخصیسازی شدهاند که میتوانید خانهی خود را به نحوی که میخواهید ساخته باشید. در مقیاس گستردهتر، با رشد جنبش خانههای کانتینر، تمام منابع موجود برای افرادی که علاقهمند به داشتن چنین خانهای هستند نیز رشد کرده است. خانه کانتینر پیش ساخته گروههای آنلاین و انجمنهای بسیاری وجود دارد که میتوانید عضو شوید تا با سازندگان خانههای کانتینر دیگر آشنا شوید. جوامع سازنده مکانهایی هستند که میتوانید کمک، مشورت یا فقط گپ زنی با افراد قبل و طی فرآیند ساخت خود داشته باشید. خانههای پیشساخته با طراحی ویژهای برای مقاومت سازهای اجرا میشوند و عملکرد لرزهای مناسبی دارند تا ایمنی را تضمین کنند. طراحی ماژولار، جابجایی آن را آسان میسازد و نصب آن قابل تنظیم است تا با ترجیحات شخصی شما در زمینهی طرحها، سبکها و انواع اتاقها سازگار باشد. تمامی اجزا پیشساخته هستند و نصب آنها ساده بوده و نیازی به مهارتهای خاصی ندارد. چه برای اداره، مسکونی، انبار یا هر کاربرد دیگری در نظر گرفته شده باشد، خانههای پیشساخته میتوانند نیازهای شما را برآورده کنند. ظاهر شیک، خطوط نرم و امکان سفارشیسازی مطابق سلیقهی شخصی شما، فضای زندگی ایدهآلی را خلق میکند. بهترین نکته این است که خانههای پیشساخته نیازی به جوشکاری در محل ندارند و ما دستورالعملهای نصب را ارائه میدهیم تا نصب آن برای شما آسانتر و سریعتر باشد. زندگی بهترین را در اختیار بگیرید و خانههای کانتینری یا خانههای پیشساخته را انتخاب کنید. امنیت و راحتی خانه خود را با نصب یک خانه کانتینری افزایش دهید! تمام اجزای سازهای در کارخانه پیشساخته میشوند. با انتخاب ابعاد، پیکربندی و سبک مناسب، میتوانید فضای زندگی خود را بهسرعت ایجاد کنید. بر اساس نیازها و سلیقهی شما، چندین ماژول را میتوان در طرحهای مختلف اتاقها تلفیق کرد تا خانههای کانتینری چندمنظورهای ایجاد شود که میتوانند بهعنوان اتاق نشیمن، آشپزخانه یا اتاق خواب استفاده شوند. نکته مهم این است که خانههای کانتینری مورد استفاده ما سازهای مستحکم و قابل جداسازی و مونتاژ آسان هستند و عملکرد عالیای از جمله ضدآب، ضدآتش و مقاوم در برابر نفوذ آب دارند؛ همچنین فرآیند نصب آنها ساده و آسان است و نیازی به مهارتهای فنی خاصی ندارد. خانههای پیشساخته کانتینری برای اهداف مختلفی از جمله زندگی شخصی، انبارداری، فضای اداری موقت و سایر کاربردها طراحی شدهاند تا نیازهای شما را برآورده کنند. امروز از امکانات یک اتاق کانتینری بهرهمند شوید، قیمت بهتری دریافت کنید و خدمات برتری را تجربه نمایید و کیفیت زندگی خود را بهبود بخشید! کابین سیب، شکل منحصر به فرد، ظاهر زیبا، خانهی شما را شخصیتر میکند. ما طیف گستردهای از رنگها و سبکها را ارائه میدهیم تا سلیقهی شما را برآورده کنیم؛ از سبکهای ساده و مدرن تا سبکهای سنتی. شرکت پکن چنگدونگ بر نیازها و خواستههای کاربران تمرکز دارد و محصولاتش قابل سفارشیسازی برای برآورده کردن نیازهای شماست. با توجه به آرزوها و سلیقهی شخصی شما، میتوانید شکل طرح خانه، چیدمان فضاهای داخلی، سیستمهای آب و برق و همچنین نحوهی توزیع آب و برق را تغییر دهید تا خانهای کامل و منحصربهفرد برای خود بسازید. پیشساختن لولههای آب و برق، از فرآیند طولانی بازچیدمان لولهها پس از اتمام دکوراسیون جلوگیری میکند و در نتیجه کارایی و کیفیت دکوراسیون را افزایش میدهد. ما گزینههای متنوعی برای چیدمان فضاهای داخلی ارائه میدهیم که شامل سالن پذیرایی و غذاخوری، اتاقهای خواب، آشپزخانه، حمام و غیره میشود. شما میتوانید گزینهای را انتخاب کنید که بیشترین تطابق را با نیازها و سلیقهی شما داشته باشد تا خانهای ایدهآل و منحصربهفرد برای خود ایجاد کنید. خانهی سیب — بالاترین سطح کیفیت زندگی! هزینهی خانههای کانتینری خانهی سیب را کشف کنید! خانه قابل جمع و باز نمود بر اساس هزینه خانه سنتی کانتینرهاست، که می تواند طبق نیازهای شما طراحی شده، به تولید انبوه برسد و محیط زندگی شما را امنتر، پایدارتر و قویتر کند. اتاق قابل استفاده به گونه ای است که می تواند نیازهای مختلف را در بر گیرد، معنی این است که شما می توانید هر جا و هر وقت راحت زندگی کنید. ارسال سریع! بسته بندی و ارسال نیز سریع است، زیرا ما از متخصصان در تیم بسته بندی خود استفاده می کنیم، طبق نیازهای شما اتاق قابل جمع را بسته بندی می کنیم و مطمئن می شویم که محصول باکیفیت ترین را دریافت کنید. ما هر مرحله از فرآیند ارسال را نظارت می کنیم تا مطمئن شویم محصولات شما به مقصد به صورت امن و امن رسیده است. خانه قابل جمع بدون لazerدر محل ساخته می شود و دستورالعمل های نصب را ارائه می دهیم تا فرآیند را سریعتر و آسانتر کنیم. اگر شما مراحل موجود در دستورالعمل را دنبال کنید، قادر خواهید بود نصب خانه قابل جمع را به راحتی تکمیل کنید. CDPH تولید و فروش انواع خانههای ماژولی، خانههای پیش ساخته و خانههای ویلا را انجام میدهد. دامنه گسترده محصولات ما به ما امکان میدهد برای هر اردوگاه مهندسی راهحل مناسبی ارائه دهیم.هزینه خانه کانتینری
ساخت خانه کانتینر واقعا چقدر هزینه دارد؟

کدام یک ارزانتر و کارآمدتر است؟

نکات برای ساخت خانه کانتینری هزینهبرداری کمتر

چرا خانههای کانتینری گزینهای کارآمد و ارزانتر هستند؟
Why choose CDPH
هزینه خانه کانتینری?
خانه پیش ساخته جدید
خانه کانتینر فروش خوب
کابین مدرن اپل
خانه پوشاکی با کیفیت بالا
چیزی که به دنبالش هستید پیدا نمیشود؟
همین حالا نقلقول درخواست کنید
برای اطلاع از محصولات بیشتر با مشاوران ما تماس بگیرید.با ما در تماس باشید
بیش از ۲۷ سال تجربه
ساخت اردوگاه مهندسی