上报方式:
// 发送图片数据
// 普通ajax发送请求数据
// sendBeacon,如果不兼容,再使用图片上传
科普小知识:
一般token生成,hash生成的格式,是36进制,也就是0至9和A至Z
Math.random().toString(36).substring(2, 9)
// '0bz4xls' 'o0hcuwy'
import config from './config'
// 一般token生成,hash生成的格式,是36进制
// 0至9和A至Z
// Math.random().toString(36).substring(2, 9)
// xhr获取
export const originalProto = XMLHttpRequest.prototype;
export const originalSend = originalProto.send;
export const originalOpen = originalProto.open;
// 生成唯一上报id
export default function generateUniqueId() {
return 'id-' + Date.now() + '-' + Math.random().toString(36).substring(2, 9)
}
// 上报函数
export function report(data) {
if (!config.report) {
console.error('请设置上传 url 地址');
}
const reporData = JSON.stringify({
id: generateUniqueId(),
data
});
// TODO 发送数据 优先使用 secdBeacon,如果不兼容,再使用图片上传
const value = beaconRequest(config.url, reporData)
if (!value) {
// 上报数据,使用图片的方式
config.isImageUpload ? imgRequest(reporData) : xhrRequest(config.url, reporData);
}
}
// 发送图片数据
export function imgRequest(data) {
const img = new Image();
img.src = `${config.url}?data=${encodeURIComponent(JSON.stringify(data))}`;
}
// 普通ajax发送请求数据
export function xhrRequest(url, data) {
let flag = true
if(window.requestIdleCallback){
return flag = window.requestIdleCallback(()=>{
const xhr = new XMLHttpRequest();
originalOpen.call(xhr, 'POST', data.url, true);
originalSend.call(xhr, JSON.stringify(data));
},{ timeout: 3000 });
} else {
setTimeout(()=>{
const xhr = new XMLHttpRequest();
originalOpen.call(xhr, 'POST', data.url, true);
originalSend.call(xhr, JSON.stringify(data));
});
}
const xhr = new XMLHttpRequest();
originalOpen.call(xhr, 'POST', data.url, true);
originalSend.call(xhr, JSON.stringify(data));
}
// sendBeacon上报方式
export function isSupportSendBeacon(){
return 'sendBeacon' in navigator;
}
// const sendBeacon = isSupportSendBeacon()? navigator.sendBeacon: xhrRequest
// beacon发送请求数据(存在兼容性)
export function beaconRequest(data){
let flag = true
if(window.requestIdleCallback){
return flag = window.requestIdleCallback(()=>{
sendBeacon(config.url ,data);
},{ timeout: 3000 });
} else {
return flag = setTimeout(()=>{
sendBeacon(config.url, data)
});
}
}