có sẵ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);
}
});
})();
Muốn chiếc xe của bạn trông nổi bật? Vành trang trí là phụ kiện tuyệt vời có thể làm được điều đó. YAOLILAI vành bánh xe có sẵn với nhiều mẫu mã và màu sắc khác nhau để chọn ra sản phẩm tốt nhất. Vành Trang Trí Astra Để Làm Xe Bạn Nhìn Nổi Bật Bánh xe của bạn có vẻ ngoài không tốt? Đừng lo lắng! Hành khách - Làm đẹp cho xe hơi của bạn với các ốp bánh xe thời trang. Có vô số thiết kế để bạn chọn lựa, làm cho xe hơi của bạn trở nên cool và khác biệt so với những chiếc khác. Dù bạn thích phong cách hiện đại, tối giản hoặc điều gì đó nổi bật và thiết kế hơn, bạn sẽ được hưởng lợi khi chọn từ các sản phẩm YAOLILAI có sẵn. đai cách vành . Khám Phá Các Ốp Mới Cho Xe Hơi Đẹp Lắp Đặt Ốp Bánh Xe Mới Để Tạo Kiểu Đẹp Cho Xe Của Bạn; Nó có thể hoàn toàn thay đổi diện mạo của bánh xe. Những ốp đơn giản hoặc nổi bật đều phù hợp với gu thời trang của bạn. Nếu bạn thích phong cách cổ điển, sạch sẽ - hoặc có lẽ điều gì đó hiện đại và thời trang hơn - thì khả năng cao là có một ốp bánh xe YAOLILAI vành tùy chỉnh đáp ứng sở thích của bạn. Khi trang trí bánh xe của bạn, bạn muốn thêm một chút phong cách vào đó, chúng tôi nghĩ rằng viền bánh xe là phụ kiện tốt nhất cho vẻ ngoài cool. Không thể phủ nhận rằng chúng làm cho chiếc xe của bạn nổi bật hơn. Không chỉ cải thiện ngoại hình của xe chúng ta mà còn thêm một chút sự tinh tế cần thiết nữa. Có nhiều chất liệu để lựa chọn khi muốn mang lại vẻ ngoài hiện đại cho bánh xe. Crom, thép không gỉ hoặc thậm chí là nhựa dẻo hơn đều là những loại viền bánh xe có sẵn cho hầu hết các bộ phận tại cửa hàng lốp và kho một lựa chọn. Những viền này thậm chí có thể làm cho chiếc xe của bạn trông tuyệt vời hơn. Chúng cung cấp một vẻ ngoài mạnh mẽ hơn đồng thời bảo vệ bánh xe khỏi những vết xước phiền toái; va chạm và lõm. Bạn có thể làm nó trông như mới. Ngoài việc mang lại diện mạo thời trang cho xe, viền bánh xe còn hoạt động như một lớp bảo vệ bổ sung nhằm cố gắng hạn chế mức độ mài mòn chung theo thời gian - giúp bánh xe trông sạch sẽ và mới hơn trong thời gian dài. Các bộ viền bánh xe cá tính giúp mang lại sức sống mới cho bánh xe của bạn. Bộ viền này có độ bền cao và bảo vệ bánh xe khỏi hư hại. Bạn có thể dễ dàng tự lắp đặt! Các bộ viền bánh xe có lẽ là một trong những cách đơn giản và dễ thực hiện nhất để tân trang bánh xe—đặc biệt phù hợp nếu bạn là người mới bắt đầu tự làm hoặc đang tìm kiếm giải pháp nâng cấp xe một cách đơn giản. Tóm lại, nói một cách đơn giản thì vành che bánh xe là một phụ kiện tuyệt vời giúp chiếc xe của bạn trông thật phong cách và cá tính! Sản phẩm có sẵn trong nhiều màu sắc và kiểu dáng khác nhau, cho phép bạn lựa chọn mẫu phù hợp nhất với sở thích của mình. Chức năng của vành che bánh xe: Ngoài việc làm tăng vẻ ngoài ấn tượng cho xe, các tấm che bánh xe còn bảo vệ bánh xe khỏi các tác nhân bên ngoài như bụi bẩn và tuyết ẩm ướt. Vậy còn chần chừ gì nữa? Nâng cấp ngay chiếc xe của bạn hôm nay — hãy sắm ngay những vành che bánh xe! Với sự đa dạng phong phú trên thị trường, bạn chắc chắn sẽ tìm được vành che bánh xe phù hợp với mọi gu thẩm mỹ — để chiếc xe của bạn thực sự nổi bật. Đội ngũ R&D của chúng tôi vừa đam mê vừa sáng tạo. Chúng tôi luôn tìm kiếm những vật liệu, công nghệ và thiết kế mới nhất. Nhờ đó, chúng tôi có thể phản ứng nhanh trước các xu hướng ngành và sản phẩm ốp vành bánh xe. Điều này giúp chúng tôi cung cấp cho quý khách những vòng thép tốt nhất nhằm đáp ứng mọi yêu cầu. Từ khâu lựa chọn nguyên vật liệu đến từng công đoạn sản xuất, chúng tôi tuân thủ nghiêm ngặt các tiêu chuẩn chất lượng và kiểm soát chặt chẽ mỗi giai đoạn trong quy trình sản xuất. Mỗi vòng thép đều trải qua nhiều lần kiểm tra để đảm bảo chất lượng ốp vành bánh xe, độ bền và độ chính xác về kích thước. Chúng tôi cam kết đảm bảo chất lượng cao. Đội ngũ dịch vụ khách hàng của chúng tôi giàu kinh nghiệm, am hiểu về ốp vành bánh xe và tận tâm. Dù là dịch vụ trước hay sau khi mua hàng, chúng tôi đều có thể cung cấp cho quý khách các dịch vụ nhanh chóng và chất lượng. Chúng tôi nhận thức rằng mỗi bộ viền bánh xe đều độc đáo và cung cấp một loạt dịch vụ cá nhân hóa. Dù thông số kỹ thuật, phong cách hay hiệu năng bạn yêu cầu, chúng tôi đều có thể thiết kế chiếc vành hoàn hảo nhằm đáp ứng đúng nhu cầu cụ thể của bạn.Liên hệ với tôi ngay lập tức nếu bạn gặp vấn đề!
Viền bánh xe
Làm cho vành xe của bạn trở nên thời thượng hơn bao giờ hết!

Một phụ kiện tuyệt vời cho trang phục của bạn

Phụ kiện để tăng cường vẻ ngoài của phương tiện của bạn

Ốp vành bánh xe phong cách: Làm mới bộ vành xe của bạn
Why choose YAOLILAI Viền bánh xe?
Đội ngũ Nghiên cứu & Phát triển Sáng tạo:
Kiểm soát chất lượng nghiêm ngặt:
Dịch vụ khách hàng chuyên nghiệp:
Dịch vụ cá nhân hóa và tùy chỉnh:
Các danh mục sản phẩm liên quan
Không tìm thấy sản phẩm bạn cần?
Yêu cầu Báo giá Ngay
Liên hệ với các chuyên viên tư vấn của chúng tôi để biết thêm các sản phẩm có sẵn.Liên hệ