



下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第JavaScript利用img實(shí)現(xiàn)前端頁面埋點(diǎn)功能目錄數(shù)據(jù)類型技術(shù)方案如何設(shè)計(jì)完整代碼總結(jié)做數(shù)據(jù)分析的時(shí)候,可能會(huì)遇到一個(gè)問題:如何獲取足量的有效數(shù)據(jù)。簡(jiǎn)單記錄用戶登錄IP肯定是不能滿足要求的,這個(gè)時(shí)候就需要我們?cè)谇岸隧撁媛顸c(diǎn),也就是數(shù)據(jù)采集點(diǎn)。如何來實(shí)現(xiàn)一個(gè)前端埋點(diǎn)功能,本文就帶你上手試試。
數(shù)據(jù)類型
首先,我們需要明確埋點(diǎn)需要哪些數(shù)據(jù),這個(gè)和具體的業(yè)務(wù)需求有關(guān)。但是我們?cè)O(shè)計(jì)的時(shí)候,還是應(yīng)該盡量考慮:
pv:頁面訪問量uv:用戶訪問量自定義事件頁面性能加載數(shù)據(jù)報(bào)錯(cuò)信息
埋點(diǎn)數(shù)據(jù)范圍清晰了,那么怎么來實(shí)現(xiàn)埋點(diǎn)呢?
技術(shù)方案
首先我們不建議使用ajax發(fā)送http的方式將埋點(diǎn)數(shù)據(jù)發(fā)送到服務(wù)端,原因主要有兩個(gè):
可能存在跨域的風(fēng)險(xiǎn),例如使用第三方的接口可能存在兼容性問題,例如使用fetch來發(fā)送請(qǐng)求就不兼容IE
其他原因也有,但不是主要的。這里,我們建議使用img或者script來實(shí)現(xiàn)埋點(diǎn)數(shù)據(jù)的發(fā)送,這兩個(gè)屬于原生的HTML屬性,兼容性比ajax要好很多,而且支持跨域。img和script如果要細(xì)分的話,還是有差異的,感興趣的朋友可以移步:詳解JavaScript發(fā)送埋點(diǎn)請(qǐng)求的兩種方式,本文將選擇img來實(shí)現(xiàn)埋點(diǎn)。
如何設(shè)計(jì)
在寫代碼前,可以先設(shè)計(jì)出代碼大概的結(jié)構(gòu),這樣在寫的時(shí)候才會(huì)思路清晰。在埋點(diǎn)數(shù)據(jù)中,性能分析和錯(cuò)誤監(jiān)聽可能會(huì)復(fù)雜一點(diǎn)。性能分析可以使用performance.timing
performance的每一個(gè)屬性的作用節(jié)點(diǎn)可參考下圖:
錯(cuò)誤監(jiān)聽可參考文章:如何監(jiān)聽Vue項(xiàng)目報(bào)錯(cuò)的4種方式
完整代碼
classStatisticsSDK{
constructor(){
this.initPerformance();//性能分析
this.initError();//錯(cuò)誤監(jiān)聽
//初始化性能分析
initPerformance(){
consturl='xxx';
this.send(url,performance.timing)
//初始化錯(cuò)誤監(jiān)聽
initError(){
window.addEventListener('error',event={
const{error,lineno,colno}=event;
this.error(error,{lineno,colno})
//Promise未catch的錯(cuò)誤
window.addEventListener('unhandledrejection',event={
this.error(newError(event.reason),{type:'unhandledrejection'})
//發(fā)送埋點(diǎn)數(shù)據(jù),作為公共方法被調(diào)用
send(url,params={}){
params.id=Date.now();//當(dāng)前時(shí)間戳
constarr=[];
for(letkeyinparams){
arr.push(`${key}=${params[key]}`);
constnewUrl=`${url}${arr.join('')}`;//參數(shù)拼接在請(qǐng)求地址上
//使用img發(fā)送埋點(diǎn)數(shù)據(jù)
//constimg=newImage();
//img.src=newUrl;
constimg=document.createElement('img');
img.src=newUrl;
//頁面訪問量
pv(){
consturl='xxxx'
//調(diào)用send發(fā)送
this.send(url,{key:'pv',value:location.href})
//自定義事件
event(key,value){
consturl='xxxx';//服務(wù)端地址
//調(diào)用send發(fā)送
this.send(url,{key,value})
//未捕獲的錯(cuò)誤,或者用戶自行發(fā)送錯(cuò)誤埋點(diǎn)數(shù)據(jù)時(shí)
error(error,info={}){
consturl='xxx';
const{message,stack}=error;
this.send(url,{message,stack,...info})
consts=newStatisticsSDK();
總結(jié)
本文主要使用img來實(shí)現(xiàn)埋點(diǎn)數(shù)據(jù)的發(fā)送,考慮了跨域、兼容性,但
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 山東工商學(xué)院《服務(wù)禮儀理論教學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 貴州水利水電職業(yè)技術(shù)學(xué)院《中醫(yī)護(hù)理技術(shù)》2023-2024學(xué)年第二學(xué)期期末試卷
- 重慶五一職業(yè)技術(shù)學(xué)院《交通運(yùn)輸安全2》2023-2024學(xué)年第二學(xué)期期末試卷
- 上海中僑職業(yè)技術(shù)大學(xué)《建筑營(yíng)造》2023-2024學(xué)年第二學(xué)期期末試卷
- 重慶建筑工程職業(yè)學(xué)院《跨媒介創(chuàng)意2》2023-2024學(xué)年第二學(xué)期期末試卷
- 北京工商大學(xué)嘉華學(xué)院《管理學(xué)原理B1》2023-2024學(xué)年第二學(xué)期期末試卷
- 新疆現(xiàn)代職業(yè)技術(shù)學(xué)院《教育學(xué)研究新進(jìn)展》2023-2024學(xué)年第二學(xué)期期末試卷
- 大連海洋大學(xué)《插畫基礎(chǔ)》2023-2024學(xué)年第二學(xué)期期末試卷
- 上海工商職業(yè)技術(shù)學(xué)院《陶瓷產(chǎn)品設(shè)計(jì)》2023-2024學(xué)年第二學(xué)期期末試卷
- 湖南交通工程學(xué)院《數(shù)字電路與數(shù)字邏輯》2023-2024學(xué)年第二學(xué)期期末試卷
- 高中政治教學(xué)的經(jīng)驗(yàn)分享課件
- 《寄冰》-完整版課件
- 內(nèi)科學(xué)-骨髓增生異常綜合征(MDS)
- 辦公室事故防范(典型案例分析)
- 地球的不同圈層英文版
- 八年級(jí)下冊(cè)英語七選五專項(xiàng)講練一
- 兩班倒排班表excel模板
- ISO31000風(fēng)險(xiǎn)管理標(biāo)準(zhǔn)中文版
- 《S7-1200-PLC-編程及應(yīng)用技術(shù)》試題試卷及答案2套
- 電土施表4-18混凝土結(jié)構(gòu)工程養(yǎng)護(hù)記錄.docx
- 醫(yī)療質(zhì)量與安全管理委員會(huì)組成與職責(zé)
評(píng)論
0/150
提交評(píng)論