안드로이드 열화상 카메라)에 대해 들어보신 적이 있나요? 이들은 열을 감지하여 우리 생명을 지켜주는 매우 유용한 도구입니다. 이러한 독특한 기기는 우리에게 위험을 경고해 줄 수 있습니다...">
,需要通过父级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);
}
});
})();
홈페이지 /
한 번 들어보셨나요 안드로이드 열 카메라 그들은 열을 감지하고 우리를 생존하게 하는 매우 유용한 도구입니다. 이 독특한 기기들은 문제가 있다는 것을 감지할 때마다 우리에게 경고를 보냅니다. 이제 우리가 방어 메커니즘을 높이기 위한 강력한 면역력을 증진시키는 도구들에 대해 더 알아볼 시간입니다. 당신의 집이나 사무실 공간이 완전히 안전하다는 확신을 가질 수 있습니다 안드로이드 열 카메라 . 그들은 열을 감지하고 일정 온도 이상으로 위험해지면 우리에게 알릴 수 있는 능력이 있습니다. 이는 특히 불을 찾을 때 유용합니다, 왜냐하면 불은 일반적으로 빠르게 열을 방출하기 때문입니다. 불이 몇 초 만에 통제 불가능해질 수 있습니다. 열 감지기를 사용하면 불이 퍼지기 전에도 이를 인지할 수 있습니다. 이로 인해 대응하고 안전을 도모할 시간을 벌 수 있습니다. 지점 안드로이드 열화상 카메라 최근 몇 년간 s는 많은 발전을 거듭해 왔으며, 이는 모두에게 매우 유익합니다! 새로운 버전들은 정말 놀라운 기능들을 가지고 있습니다. 이 중에는 비상 상황이 발생할 경우 소방서에 알릴 수 있는 경보기가 포함됩니다. 이를 통해 우리가 집에 있지 않더라도 화재가 발생하면 경보가 울리고, 도움이 매우 신속하게 올 수 있습니다. 일부 감지기는 구조물 내 여러 지역의 온도를 감지할 수도 있습니다. 이것은 소방대원들에게 화재가 어디에 있을 수 있으며, 도착 시 얼마나 큰(또는 작은) 화재를 마주할지에 대한 정보를 제공하기 때문에 매우 중요한 자료입니다. 따라서 항상 자신의 안드로이드 열화상 카메라 잘 작동합니다. 가장 필요할 때 고장날 수 있기 때문에 주의해야 합니다! 다른 말로, 최고의 수질 테스트 키트가 필요한 장치를 정기적으로 확인하는 것이 중요합니다. 또한, 이를 적절한 위치에 두어 올바르게 작동하도록 하고 평소처럼 깨끗하게 유지해야 합니다. 만약 감지기가 작동할 것이라고 100% 확신하지 못한다면, 경험이 있는 사람에게 도움을 요청하여 장치의 알람이 실제로 울리는지 테스트하는 것이 좋습니다. 이는 감지기가 제대로 작동하고 당신을 보호할 수 있는지 확인하는 데 매우 좋은 방법입니다. 화재가 발생했을 때 시간은 매우 중요합니다. 강력한 기능: 집이나 사무실에서 나올 수 있도록 귀중한 사전 경고를 줄 수 있습니다. 이 조기 경고는 화재가 커지기 전에 당신과 가족이 안전하게 탈출할 기회를 주기 때문에 매우 중요합니다. 안전이 핵심이며, 열 감지기는 생명을 구하는 도구가 될 수 있습니다. 이를 상징적으로 표현하면, 불미스러운 사고를 감시하는 경비원과 같은 역할을 한다고 볼 수 있습니다. 열 감지기는 집, 직장, 자동차 심지어 비행기와 같은 다양한 공간에서 사용할 수 있습니다. 그들은 많은 다른 환경에 적응할 수 있기 때문에 유연합니다. 일부 감지기는 열뿐만 아니라 일산화탄소와 같은 독성 가스도 추적할 수 있습니다. 따라서 우리는 다양한 상황에서 보호받는데 있어 매우 유용합니다. 더 간단히 말하자면, 열 감지기를 사용하면 가스가 있을 경우 이를 경고하여 치명적인 상황이 되기 전에 아무런 나쁜 일이 일어나지 않도록 해줍니다. LSJ는 고객에게 고품질 제품과 열 감지기(thermal heat detector)를 제공하는 것이 얼마나 중요한지를 잘 인식하고 있습니다. 당사는 1년 또는 5년의 보증 기간을 제공함으로써, 자사 제품의 오랜 수명과 우수한 성능에 대한 확신을 표현합니다. 당사는 연구개발(R&D)에 막대한 투자를 실시함으로써, 고객의 제품이 최고 수준의 기준을 충족하도록 보장합니다. 제조업체로서 당사는 원자재 조달 단계부터 생산 완료까지 엄격한 품질 관리 절차를 준수합니다. 개인 고객이든, 유통업체이든, 입찰 참가자이든, 정부 기관이든 상관없이, 귀하의 요구사항을 충족시키는 다양한 제품군을 제공합니다. 당사의 원자재, 부품 및 기타 관련 품목 재고는 충분히 풍부하여 신속한 납기를 보장합니다. 만일 약정된 시일 내 납품이 불가능할 경우, 당사는 주문 총액의 2%~50%를 고객에게 환불해 드릴 것을 약속합니다. 당사는 제품을 효율적으로 사용하실 수 있도록 상세한 사용 설명서와 동영상 자료를 제공합니다. 또한 귀하의 구체적인 요구사항에 맞춘 현장 기술 교육을 직접 실시하여, 제품을 자신 있게 그리고 쉽게 활용하실 수 있도록 지원합니다. 고품질·고신뢰성 제품과 뛰어난 고객 서비스를 원하신다면 LSJ를 선택해 주십시오. 2013년 이래, LSJ는 열화상 탐지기의 개발, 제조 및 고성능 수색·구조 장비 및 소방 장비 공급을 전문으로 해오고 있습니다. LSJ는 ISO9001, CE, ROHS 인증을 획득하였으며, 30건 이상의 특허를 보유하고 있습니다. 선도 기업으로서, 당사는 디자인 및 연구 부문에 막대한 투자를 지속적으로 실시하고 있습니다. LSJ는 2024년 INTERSEC, Securika, 말레이시아에서 개최된 제18차 Defence Services Asia 및 제3차 National Security Asia, 미국에서 개최된 NFPA 등 4개 주요 국제 전시회에 참가하였습니다. 2025년에는 1월 14일부터 16일까지 두바이에서 개최되는 INTERSEC 전시회에 참가할 예정입니다. 당사는 열화상 소방 카메라, 음향·영상 감시 장비, 가스 탐지기, 3D 레이더 등 다양한 제품을 전시할 계획입니다. 귀하의 부스 방문을 진심으로 초대합니다. 제조 분야에서 11년 이상의 풍부한 경험을 바탕으로, LSJ는 고객의 실제 사용 환경에 기반한 신제품 재설계 및 제조를 전문으로 하며, 지속적인 기능 개선과 비용 절감을 추구합니다. 또한 LSJ는 도시 구조·수색 분야에 대한 심층적인 전문 지식을 보유하고 있습니다. 예를 들어, 2023년 터키 지진 당시 LSJ의 라디오 생명 탐지기는 중국 ‘블루스카이 구조대’의 구조 활동에서 핵심적인 역할을 수행하였습니다. 귀사의 특정 요구 사항에 맞춘 첨단적이고 신뢰성 높은 솔루션을 위해 LSJ를 선택해 주십시오. 열 감지기(thermal heat detector)는 국제 표준을 충족하는 고품질 도시 탐색 및 구조(Urban Search and Rescue) 장비 개발 분야의 시장 선도 기업입니다.
사전 판매 서비스(Pre-Sales Service):
저희는 고객 지원을 처음부터 시작합니다. 고객의 특정 요구 사항을 정확히 파악하고 맞춤형 솔루션을 제시하기 위해 종합적인 상담 서비스를 제공합니다. 또한 기술 사양서와 제품 데모를 통해 고객이 현명한 결정을 내릴 수 있도록 지원합니다.
판매 서비스(Sales Service):
저희는 전체 판매 과정이 매끄럽고 효율적으로 이루어지도록 보장합니다. 체계화된 주문 시스템과 엄격한 품질 관리를 통해 제품이 예정된 시일에 완벽한 상태로 고객에게 도착하도록 보장합니다. 도어-투-도어(Door-to-Door) 배송도 지원합니다.
사후 서비스(After-Sales Service):
제품 수령 후에도 고객과의 관계는 종료되지 않습니다. 설치 관련 조언, 사용자 교육, 정비 서비스 등 포괄적인 사후 지원을 제공합니다. 고객 문의나 문제 해결을 위해 고객 서비스 팀이 항상 즉시 대응하여 고객 만족을 최우선으로 합니다. LSJ에서 장비를 구매하시면 3년간의 보증 서비스를 제공합니다. 또한 구매 후에는 전용 사후 지원을 별도로 제공해 드립니다.
LSJ를 선택한다는 것은 신뢰, 품질, 그리고 차별화된 지원을 선택하는 것입니다. 저희는 도시 탐색 및 구조(Urban Search and Rescue) 또는 소방 분야에서 귀사의 파트너가 되어 드리기를 진심으로 기대합니다. 저희는 소방 및 구조대, 공공 안전 서비스, 도시 지역 수색 및 구조 팀, 기타 군부대를 대상으로 서비스를 제공합니다. LSJ는 다양한 산업 분야에서 화재 진압, 수색 및 구조 활동, 위험 지역 작업을 수행하기 위한 첨단 장비를 제공합니다. 소방용 열화상 카메라: 저희는 해상도가 세 가지인 두 종류의 열화상 카메라를 개발하고 연구했습니다. 이 카메라는 최고 2000°C까지의 온도를 측정할 수 있습니다. 수색 및 구조 장비: 당사 제품군에는 레이더 생명 탐지기, 벽을 통한 열 감지기, 구조물 안정성 모니터, 움직임 감시 시스템, 가스 탐지기 등이 포함됩니다. 산업용 열화상 카메라: LSJ의 열화상 카메라는 소방 활동에만 국한되지 않고, 건물 점검, 전자 기기 수리, 누수 탐지, HVAC 시스템 점검 등에도 활용됩니다. 열화상 스코프 및 야간 투시 스코프: 당사의 야간 투시 스코프는 야간 시인성을 위해 최적화되어 사냥꾼들 사이에서 인기가 높으며, 소총에 쉽게 장착할 수 있습니다. LSJ는 다양한 산업 분야의 요구를 충족시키는 고품질 열화상 구조 및 영상 장비를 제공함으로써 효율성과 안전성을 높여 드립니다. LSJ는 가장 신뢰성 높고 혁신적인 솔루션을 제공합니다. 도시 지역 수색 및 구조 작전을 위한 주요 파트너로 LSJ를 믿어 주십시오. 저작권 © 베이징 LSJ 테크놀로지 디벨롭먼트 코., 리미티드. 모든 권리 보유
-
개인정보 보호정책
열 감지기
최신 열 감지 기술로 화재 안전성 향상시키기

신뢰할 수 있는 열 감지기와 함께 경각심을 유지하고 안전하게 지내기
열 감지기가 어떻게 생명을 구할 수 있는가

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