JavaScript利用img實現(xiàn)前端頁面埋點功能_第1頁
JavaScript利用img實現(xiàn)前端頁面埋點功能_第2頁
JavaScript利用img實現(xiàn)前端頁面埋點功能_第3頁
JavaScript利用img實現(xiàn)前端頁面埋點功能_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

第JavaScript利用img實現(xiàn)前端頁面埋點功能目錄數(shù)據(jù)類型技術(shù)方案如何設(shè)計完整代碼總結(jié)做數(shù)據(jù)分析的時候,可能會遇到一個問題:如何獲取足量的有效數(shù)據(jù)。簡單記錄用戶登錄IP肯定是不能滿足要求的,這個時候就需要我們在前端頁面埋點,也就是數(shù)據(jù)采集點。如何來實現(xiàn)一個前端埋點功能,本文就帶你上手試試。

數(shù)據(jù)類型

首先,我們需要明確埋點需要哪些數(shù)據(jù),這個和具體的業(yè)務(wù)需求有關(guān)。但是我們設(shè)計的時候,還是應(yīng)該盡量考慮:

pv:頁面訪問量uv:用戶訪問量自定義事件頁面性能加載數(shù)據(jù)報錯信息

埋點數(shù)據(jù)范圍清晰了,那么怎么來實現(xiàn)埋點呢?

技術(shù)方案

首先我們不建議使用ajax發(fā)送http的方式將埋點數(shù)據(jù)發(fā)送到服務(wù)端,原因主要有兩個:

可能存在跨域的風(fēng)險,例如使用第三方的接口可能存在兼容性問題,例如使用fetch來發(fā)送請求就不兼容IE

其他原因也有,但不是主要的。這里,我們建議使用img或者script來實現(xiàn)埋點數(shù)據(jù)的發(fā)送,這兩個屬于原生的HTML屬性,兼容性比ajax要好很多,而且支持跨域。img和script如果要細分的話,還是有差異的,感興趣的朋友可以移步:詳解JavaScript發(fā)送埋點請求的兩種方式,本文將選擇img來實現(xiàn)埋點。

如何設(shè)計

在寫代碼前,可以先設(shè)計出代碼大概的結(jié)構(gòu),這樣在寫的時候才會思路清晰。在埋點數(shù)據(jù)中,性能分析和錯誤監(jiān)聽可能會復(fù)雜一點。性能分析可以使用performance.timing

performance的每一個屬性的作用節(jié)點可參考下圖:

錯誤監(jiān)聽可參考文章:如何監(jiān)聽Vue項目報錯的4種方式

完整代碼

classStatisticsSDK{

constructor(){

this.initPerformance();//性能分析

this.initError();//錯誤監(jiān)聽

//初始化性能分析

initPerformance(){

consturl='xxx';

this.send(url,performance.timing)

//初始化錯誤監(jiān)聽

initError(){

window.addEventListener('error',event={

const{error,lineno,colno}=event;

this.error(error,{lineno,colno})

//Promise未catch的錯誤

window.addEventListener('unhandledrejection',event={

this.error(newError(event.reason),{type:'unhandledrejection'})

//發(fā)送埋點數(shù)據(jù),作為公共方法被調(diào)用

send(url,params={}){

params.id=Date.now();//當(dāng)前時間戳

constarr=[];

for(letkeyinparams){

arr.push(`${key}=${params[key]}`);

constnewUrl=`${url}${arr.join('')}`;//參數(shù)拼接在請求地址上

//使用img發(fā)送埋點數(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})

//未捕獲的錯誤,或者用戶自行發(fā)送錯誤埋點數(shù)據(jù)時

error(error,info={}){

consturl='xxx';

const{message,stack}=error;

this.send(url,{message,stack,...info})

consts=newStatisticsSDK();

總結(jié)

本文主要使用img來實現(xiàn)埋點數(shù)據(jù)的發(fā)送,考慮了跨域、兼容性,但

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論