자동 유압 프레스 기계를 고려해야 합니다...">
,需要通过父级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);
}
});
})();
한 자동 하이드라울릭 프레스 머신 다양한 제품을 더 빠르고 정확하게 찢어줄 샘플러를 찾고 있다면 고려해볼 사항입니다. 이러한 장치들은 절삭 과정을 용이하게 하고 가속화시킵니다. Nadun은 이러한 기계들을 제작하는 유명한 브랜드로, 모든 종류의 절삭 작업에 맞춰 설계된 자동 절단기 제조업체입니다. 기계 내부에는 직선으로 위아래로 움직이는 특수 날개가 있습니다. 매우 날카로운 가장자리를 가지고 있어 금속, 플라스틱 심지어 천까지 잘라낼 수 있습니다. 이 기계의 큰 특징 중 하나는 속도입니다 -- 빠르다는 것은 가능한 한 빠르게 재료를 절단할 수 있다는 것을 의미합니다. 또한 사람들의 도움 없이 절삭이 이루어져 시간과 에너지를 많이 절약하며, 완전히 자동화되어 있습니다. 또 다른 장점은 하이드라울릭 프레스 자동화 노무를 절감한다는 것입니다. 이 기계는 완전히 자동화되어 있어 작업 중 지속적인 감독이 필요하지 않습니다. 이 기계는 휴식 없이 오랜 시간 동안 재료를 자르는 능력을 가지고 있어 바쁜 기업들에게 인상적인 특징입니다. 이를 통해 기업들은 더 적은 노동자로도 재료를 더 빠르게 절단할 수 있습니다. 다른 장점은 숙련된 조작자가 한 명이 동시에 여러 대의 절단기를 다룰 수 있다는 것입니다. 이는 기본적으로 한 사람이 여러 시스템을 동시에 관리할 수 있도록 하는 것이며, 많은 사람들이 여러 기계를 운영해야 할 필요가 없게 합니다. 이는 단지 인력과 노동 비용을 절감하는 데 도움을 주기만 아니라 시간이 지남에 따라 기업이 생산량을 확대할 수 있게 해줍니다. 이는 특히 빠르게 대량의 출력물을 배치 생산해야 하는 회사에게 매우 중요합니다. 자동 절단기에 투자하면 생산 능력을 크게 향상시킬 수 있습니다. 고속뿐만 아니라 정확한 적절한 기계를 사용하면 기업이 재료를 효과적으로 절단할 수 있습니다. 즉, 기업은 더 적은 시간에 더 많은 제품을 생산할 수 있습니다. 절단 작업이 일상적인 작업의 큰 부분인 금속 가공업체와 같은 사업에서는 자동 절단기를 종종 사용하는데, 이는 수요에 맞추는 데 아주 좋은 방법이기 때문입니다. 자동 절단기는 효율성뿐만 아니라 상당한 수준의 다용성을 처리할 수 있어 다양한 절단 작업에 유용합니다. 재료에서 모양을 자르거나 직선으로 자르는 작업 모두 가능합니다. 나둔(Nadun)의 완전 자동 절단기는 이러한 작업과 다른 작업들을 쉽게 수행하고 비용을 절감하는 기능을 제공합니다. 자동 절단기를 유지보수하는 것은 비교적 쉬우며 큰 노력이 필요하지 않습니다. 이 기계는 움직이는 부품이 적어 거의 유지보수가 필요 없으며, 원활한 작동을 위해 자주 청소하고 윤활해야 합니다. 또한 날개를 갈아야 잘 자릅니다. 이를 제외하면, 나둔(Nadun)은 고객들에게 보증과 정기적인 유지보수 서비스를 제공하여 기계의 수명을 오래 유지시킵니다. 나둔 머신리는 금속 가공 분야에서 명성이 높은 수출업체이자 제조업체로서 17년 이상의 경험을 보유하고 있습니다. 당사는 펀치 프레스, 유압 프레스, 전단 및 굴곡 기계, 세로 선반 등을 중심으로 자동차 제조, 항공우주, 기계 공학, 건설, 야금 산업 등 다양한 산업 분야에 서비스를 제공합니다. 당사의 제품은 전 세계 150개 이상의 국가에 판매되며, 제조 기계 분야에서 새로운 기준을 수립하고 있습니다. 냉각 제품에 대한 시장 수요를 충족하기 위해 Dragon and Tiger 및 Temple of Heaven 자동 전단 기계는 다양한 유형의 사용자와 소비자에게 맞춤 조정이 가능한 폭넓은 제품을 제공합니다. 건강 및 웰빙 분야에서 브랜드 제품 개발과 사용자 경험을 기반으로 하여, 이 회사는 헬스케어 부문의 엘리트 기업이 되겠다는 목표를 세우고 있습니다. 해당 기업은 매년 400대 이상의 자동 전단 기계에 대해 설치 및 가동 조정 서비스를 제공합니다. 연간 500세트에서 600세트 사이의 다양한 제품을 제조하며, 이러한 제품들은 ISO, CE 및 SGS 인증을 획득했습니다. 당사가 보유한 다수의 제품 혁신 특허와 수상한 영예로운 인증서들은 뛰어난 품질에 대한 우리의 약속을 반영하고 있습니다. 난둔 기계는 고품질의 고효율 제품과 더불어 오랜 서비스 수명을 자랑하는 내구성으로 잘 알려져 있습니다. 난둔 기계의 연구 개발 팀은 각각 10년 이상의 연구 개발 경험을 보유한 10명 이상의 인원으로 구성되어 있습니다. 이들은 시장의 요구를 충족시키기 위해 지속적으로 자동 절단 기계를 개선하고 제품을 업그레이드하고 있습니다. 저작권 © 나둔 기계 제조 회사. 모든 권리 보유
-
개인정보 보호정책
나둔 머신리 매뉴팩처 코., 래드.
자동 절단 머신
자동 절단기와 함께하는 노동 절감 기술

자동 절단기를 사용하여 생산 능력 향상시키기

자동 절단기와 다양한 절단 응용 프로그램

자동 절단 기계를 사용하면 최소한의 유지보수만 필요합니다."
Why choose 나둔(Nadun)
자동 절단 머신?
회사의 전문성과 글로벌 네트워크:
다양한 제품
신뢰성 있는 제품 품질
우수한 품질과 성능:
원하는 내용을 찾지 못하셨나요?
지금 견적 요청하기
더 많은 이용 가능한 제품은 전문가와 상담해 주세요.문의하기