라고 불리는 이 장치는 당신을 돕는 매우 훌륭한 도구입니다...">
,需要通过父级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);
}
});
})();
홈페이지 /
당신과 가정을 모두 보호하기 위해 특별히 설계된 카메라에 대해 알고 계십니까? 그것은 열 카메라 라고 불리며, 집안의 숨겨진 문제를 찾아내고 에너지를 절약하는 데 도움이 되는 매우 유용한 도구입니다! LSJ Technology에서는 열화상 카메라의 사용이 집 점검을 더 효과적으로 만들고 삶을 더욱 편리하게 만들어 줄 수 있는 이유를 설명해 드립니다. 그러면 열화상 카메라는 정확히 무엇일까요? 마치 눈으로는 볼 수 없는 것을 볼 수 있는 마법의 안경이 있다고 상상해 보세요! 바로 그것이 바로 열화상 카메라입니다! 열 카메라 집안의 다양한 부분에 열과 냉기를 감지하여 누수나 전기적 문제와 같이 위험할 수 있는 문제를 찾아낼 수 있는 LSJ Technology의 열화상 카메라로 가정과 가족을 보호할 수 있습니다. 가끔씩 벽 안쪽이나 바닥 아래에서 눈에 띄지 않아 정확히 파악하기 어려운 문제가 발생할 수 있습니다. 하지만 열화상 카메라를 사용하면 이러한 보이지 않는 문제도 쉽게 확인할 수 있습니다! 열화상 카메라를 활용하면 물이 새는 장치, 단열재 결손, 또는 주거 공간을 방해하는 원치 않는 곤충까지도 찾아낼 수 있습니다. 이러한 문제들을 조기에 발견한다면 열 카메라 lSJ Technology 제품을 통해 절약한 시간과 비용을 향후 더 큰 수리 및 프로젝트에 투자할 수 있습니다. 냉난방 조절이 에너지 요금에서 가장 큰 비용 중 하나를 차지할 수 있다는 사실을 알고 계셨나요? 열화상 카메라를 사용하면 가정의 에너지 요금 절감에 도움이 될 수 있습니다! 열화상 카메라와 실내의 뜨겁거나 차가운 공기가 새어 나가는 위치를 파악함으로써 단열재를 추가하거나 누풍을 막는 간단한 조치를 취할 수 있으며, 이는 집을 따뜻하게 유지하고 지출도 줄이는 데 도움이 됩니다. LSJ Technology의 열화상 카메라는 이러한 에너지 낭비 지점을 찾아내는 데 도움을 주어, 가정의 에너지 효율을 높일 수 있도록 해줍니다. 누구도 예기치 않은 집 수리를 반기지 않지만, 열화상 카메라는 문제가 커지기 전에 이를 조기에 발견하는 데 도움을 줄 수 있습니다. 정기적으로 열화상 카메라로 집을 스캔하면 물 피해, 곰팡이 또는 배선 불량과 같은 문제를 큰 손실과 비용이 발생하기 전에 미리 발견할 수 있습니다. LSJ Technology의 열화상 카메라를 구입하는 것은 재난이 발생하기 전에 이를 방지해주는 초능력을 가진 동료를 두는 것과 같습니다. LSJ는 최고 수준의 국제 기준을 충족하도록 제작된 고품질 도시 탐색 및 구조 장비 생산 분야의 전문 기업입니다.
사전 판매 서비스:
저희는 고객님을 처음부터 지원해 드립니다. 고객님의 개별 요구 사항을 파악하고 맞춤형 솔루션을 제공하기 위해 종합적인 컨설팅을 실시합니다. 또한, 정보에 기반한 의사결정을 돕기 위해 상세한 기술 사양서와 제품 시연을 제공합니다.
판매 서비스:
저희는 판매 프로세스가 원활하고 효율적으로 이루어지도록 보장합니다. 간편한 주문 절차와 엄격한 품질 관리를 통해 귀하의 제품이 예정된 시간에 훌륭한 상태로 도착함을 보장합니다. 도어투도어(Door-to-Door) 배송도 지원합니다.
사후 서비스:
제품 인도 후에도 저희와의 관계는 끝나지 않습니다. 포괄적인 사후 지원에는 설치 지원, 사용자 교육, 정비 서비스가 포함됩니다. 고객 지원 팀은 귀하께서 겪을 수 있는 모든 우려 사항이나 문제에 대해 즉각 대응할 준비가 되어 있습니다. 귀하의 완전한 만족을 약속드립니다. LSJ에서 장비를 구매하시면 3년간의 보증 서비스를 제공합니다. 또한, 특정 사후 서비스를 별도로 요청하실 수 있습니다.
LSJ를 선택한다는 것은 품질, 서비스, 그리고 경쟁력 없는 지원에 대한 신뢰를 선택하는 것입니다. 저희는 도시 탐색 및 구조 분야뿐 아니라 소방 분야에서도 귀하의 믿음직한 파트너가 되기를 기대합니다. 2013년 이래로 LSJ는 주택 점검용 열화상 카메라를 비롯해 구조 및 소방관 장비용 고성능 장비의 개발, 제조 및 공급을 전문으로 해오고 있습니다. LSJ는 ISO9001, CE, ROHS 인증을 획득하였으며, 30건 이상의 특허를 보유하고 있습니다. 당사는 선도 기업으로서 연구 및 설계 부서에 막대한 투자를 지속하고 있습니다. 2024년 LSJ는 두바이 INTERSEC, 러시아 세큐리카(SECURIKA) 2024, 말레이시아에서 개최된 제18차 방위 서비스 아시아(DSA), 제3차 내셔널 시큐리티 아시아(NATSEC) 및 미국 NFPA 등 총 4개의 주요 전시회에 참가하였습니다. 또한 LSJ는 2025년 1월 14일~16일 두바이 INTERSEC 전시회에 등록되어 있습니다. 이 자리에서는 벽체 탐지, 가스 탐지, 음향·영상 청취 장비, 안정성 모니터링 장비 및 화재 진압용 열화상 카메라를 포함한 실시간 레이더 탐지기(3D 레이더)를 공개할 예정입니다. 귀하의 방문을 진심으로 초대합니다. LSJ는 11년간의 제조 경험을 바탕으로 고객의 실제 사용 시나리오에 기반한 신제품 개발 및 구축 분야의 전문 기업입니다. 또한 제품의 성능 향상과 원가 절감을 위한 노력을 꾸준히 이어가고 있습니다. LSJ는 도시 지역 구조 및 구조 활동 분야에서도 풍부한 경험을 보유하고 있습니다. 예를 들어, 2023년 터키 지진 당시 중국 블루스카이 구조대(BLUE SKY RESCUE TEAM)의 구조 작업에서 LSJ의 생명 탐지 레이더는 핵심적인 역할을 수행하였습니다. 귀사의 요구사항에 정확히 부합하는 첨단적이고 신뢰성 높은 솔루션을 위해 LSJ를 선택해 주십시오. 저희는 소방 및 구조대, 주택 점검용 열화상 카메라, 도시 탐색 및 구조팀(Urban Search and Rescue Teams), 그리고 다양한 군부대에 서비스를 제공합니다. LSJ는 다양한 산업 분야에서 화재 진압, 탐색 및 구조 활동, 폭발 위험 환경에서의 작업을 위한 혁신적인 장비를 공급합니다. 소방용 열화상 카메라: 저희는 해상도가 세 가지인 두 종류의 열화상 카메라를 자체 설계 및 연구 개발하였습니다. 이 카메라는 최대 2000°C까지 온도를 측정할 수 있습니다. 탐색 및 구조 장비: 당사는 가스 탐지기, 안정성 모니터, 움직임 감시 시스템 등 다양한 제품을 제공합니다. 산업용 열화상 카메라: LSJ는 소방 외에도 건물 점검, 전자기기 수리, 누수 탐지, HVAC 시스템 점검 등 다양한 용도로 사용 가능한 열화상 카메라를 제공합니다. 열화상 스코프: 야간 시야 확보에 이상적인 열화상 야간 투시 스코프(Night Vision Scopes)는 사냥꾼들 사이에서도 인기가 높으며, 소총에 쉽게 장착할 수 있습니다. LSJ는 다양한 산업 분야의 요구사항을 충족하는 고품질 열화상 구조 및 영상 장비를 제공함으로써 고객사의 안전성과 업무 효율성을 높여 드립니다. 최첨단이자 신뢰성 높은 솔루션을 원하신다면 반드시 LSJ를 선택해 주십시오. 도시 탐색 및 구조(USAR) 분야에서의 첫 번째 파트너로서 LSJ를 믿어 주시기 바랍니다. 가정 점검용 열화상 카메라 — LSJ는 고객에게 최고 품질의 제품과 우수한 서비스를 제공하는 것이 얼마나 중요한지 잘 알고 있습니다. 따라서 당사는 자사 제품의 내구성과 성능에 대한 확신을 바탕으로 1년 또는 5년의 보증 기간을 제공합니다. 당사는 제품이 최고 수준을 충족하도록 지속적인 연구개발(R&D)에 전념하고 있습니다. 제조사로서 당사는 원자재 조달 단계부터 생산까지 엄격한 품질 관리를 실시합니다. 개인 구매자, 유통업체, 입찰 참가자, 나아가 정부 기관에 이르기까지 다양한 고객 유형에 맞춰 귀하의 요구사항을 충족시키는 다양한 제품군을 보유하고 있습니다. 또한 원자재 및 기타 부품에 대한 탄탄한 재고를 유지하여 모든 주문에 대해 신속한 납기를 보장합니다. 만일 약정된 기한 내 납기를 이행하지 못할 경우, 당사는 고객에게 구매 금액의 2%에서 5%에 해당하는 금액을 환불해 드립니다. 당사 제품을 효율적으로 활용하고 그 가치를 최대한 발휘하실 수 있도록, 상세한 사용법 동영상 강의를 제공합니다. 더불어 귀하의 구체적인 요구사항에 맞춘 현장 기술 교육을 위해 당사 기술 인력을 파견해 드릴 수 있습니다. 이를 통해 귀하는 당사 제품을 자신 있게, 그리고 여유 있게 사용하실 수 있습니다. 고품질·신뢰성 높은 제품과 탁월한 고객 서비스를 누리시려면 LSJ를 선택해 주십시오. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 보호정책
가정 점검용 열화상 카메라
열화상 카메라로 집 안의 숨겨진 문제 진단하기

열화상 점검을 통한 에너지 효율 개선

열화상 이미징으로 문제가 악화되기 전에 잠재적 문제 발견하기

집 점검용 열화상 카메라로 마음의 평안을 투자하세요.
Why choose LSJ Technology 가정 점검용 열화상 카메라?
왜 LSJ가 당신의 프라이머 제조업체 및 공급업체가 될 수 있는지?
고성능 수색 구조 장비 제조업체 혁신
완벽한 도시 구조물 탐색 및 구조 장비 공급망
품질과 적시 배송 보장: LSJ의 고객 만족 약속
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기