



下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第JavaScript利用img實現前端頁面埋點功能目錄數據類型技術方案如何設計完整代碼總結做數據分析的時候,可能會遇到一個問題:如何獲取足量的有效數據。簡單記錄用戶登錄IP肯定是不能滿足要求的,這個時候就需要我們在前端頁面埋點,也就是數據采集點。如何來實現一個前端埋點功能,本文就帶你上手試試。
數據類型
首先,我們需要明確埋點需要哪些數據,這個和具體的業務需求有關。但是我們設計的時候,還是應該盡量考慮:
pv:頁面訪問量uv:用戶訪問量自定義事件頁面性能加載數據報錯信息
埋點數據范圍清晰了,那么怎么來實現埋點呢?
技術方案
首先我們不建議使用ajax發送http的方式將埋點數據發送到服務端,原因主要有兩個:
可能存在跨域的風險,例如使用第三方的接口可能存在兼容性問題,例如使用fetch來發送請求就不兼容IE
其他原因也有,但不是主要的。這里,我們建議使用img或者script來實現埋點數據的發送,這兩個屬于原生的HTML屬性,兼容性比ajax要好很多,而且支持跨域。img和script如果要細分的話,還是有差異的,感興趣的朋友可以移步:詳解JavaScript發送埋點請求的兩種方式,本文將選擇img來實現埋點。
如何設計
在寫代碼前,可以先設計出代碼大概的結構,這樣在寫的時候才會思路清晰。在埋點數據中,性能分析和錯誤監聽可能會復雜一點。性能分析可以使用performance.timing
performance的每一個屬性的作用節點可參考下圖:
錯誤監聽可參考文章:如何監聽Vue項目報錯的4種方式
完整代碼
classStatisticsSDK{
constructor(){
this.initPerformance();//性能分析
this.initError();//錯誤監聽
//初始化性能分析
initPerformance(){
consturl='xxx';
this.send(url,performance.timing)
//初始化錯誤監聽
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'})
//發送埋點數據,作為公共方法被調用
send(url,params={}){
params.id=Date.now();//當前時間戳
constarr=[];
for(letkeyinparams){
arr.push(`${key}=${params[key]}`);
constnewUrl=`${url}${arr.join('')}`;//參數拼接在請求地址上
//使用img發送埋點數據
//constimg=newImage();
//img.src=newUrl;
constimg=document.createElement('img');
img.src=newUrl;
//頁面訪問量
pv(){
consturl='xxxx'
//調用send發送
this.send(url,{key:'pv',value:location.href})
//自定義事件
event(key,value){
consturl='xxxx';//服務端地址
//調用send發送
this.send(url,{key,value})
//未捕獲的錯誤,或者用戶自行發送錯誤埋點數據時
error(error,info={}){
consturl='xxx';
const{message,stack}=error;
this.send(url,{message,stack,...info})
consts=newStatisticsSDK();
總結
本文主要使用img來實現埋點數據的發送,考慮了跨域、兼容性,但
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 職業生涯規劃教案第一課課
- 職業生涯規劃與理想課件模
- 江蘇省宿遷市泗洪中學2025屆高一化學第二學期期末復習檢測試題含解析
- 2025年老年服務項目立項申請報告
- 廣東肇慶市2025年高二下化學期末學業水平測試模擬試題含解析
- 中國珍珠酪行業市場發展前景及發展趨勢與投資戰略研究報告(2024-2030)
- 2025屆湖北省鄂東南省級示范高中教育教學改革聯盟學校高一化學第二學期期末調研試題含解析
- 雕金盤行業深度研究分析報告(2024-2030版)
- 2025年C35-專用設備制造業001-行業研究報告
- 2025年中國阿斯巴甜行業發展監測及投資戰略規劃研究報告
- GB/T 11177-1989無機膠粘劑套接壓縮剪切強度試驗方法
- GB 28755-2012簡易升降機安全規程
- 鈷領域:華友鈷業企業組織結構及部門職責
- 內容參考zipc教程
- FZ/T 43022-2011莨綢工藝飾品
- 基金投資管理系統O32用戶手冊-股指期貨套保系統
- 機械原理課程設計-自動打印機設計說明書
- 冰山模型提出者麥克利蘭教授6族勝任力分析模型
- 建設工程消防設計審查申報表
- 江西省中考語文備考及答題技巧——語文考點及答題策略-人教版初中九年級全冊語文素材
- 成立生物安全委員會及工作制度管理辦法和職責
評論
0/150
提交評論