JavaScript利用img實(shí)現(xiàn)前端頁(yè)面埋點(diǎn)功能
做數(shù)據(jù)分析的時(shí)候,可能會(huì)遇到一個(gè)問(wèn)題:如何獲取足量的有效數(shù)據(jù)。簡(jiǎn)單記錄用戶登錄IP肯定是不能滿足要求的,這個(gè)時(shí)候就需要我們?cè)谇岸隧?yè)面埋點(diǎn),也就是數(shù)據(jù)采集點(diǎn)。如何來(lái)實(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:頁(yè)面訪問(wèn)量
- uv:用戶訪問(wèn)量
- 自定義事件
- 頁(yè)面性能加載數(shù)據(jù)
- 報(bào)錯(cuò)信息
埋點(diǎn)數(shù)據(jù)范圍清晰了,那么怎么來(lái)實(shí)現(xiàn)埋點(diǎn)呢?
技術(shù)方案
首先我們不建議使用ajax發(fā)送http的方式將埋點(diǎn)數(shù)據(jù)發(fā)送到服務(wù)端,原因主要有兩個(gè):
- 可能存在跨域的風(fēng)險(xiǎn),例如使用第三方的接口
- 可能存在兼容性問(wèn)題,例如使用fetch來(lái)發(fā)送請(qǐng)求就不兼容IE
其他原因也有,但不是主要的。這里,我們建議使用<img>
或者<script>
來(lái)實(shí)現(xiàn)埋點(diǎn)數(shù)據(jù)的發(fā)送,這兩個(gè)屬于原生的HTML屬性,兼容性比ajax要好很多,而且支持跨域。img和script如果要細(xì)分的話,還是有差異的,感興趣的朋友可以移步:詳解JavaScript發(fā)送埋點(diǎn)請(qǐng)求的兩種方式,本文將選擇img來(lái)實(shí)現(xiàn)埋點(diǎn)。
如何設(shè)計(jì)
在寫(xiě)代碼前,可以先設(shè)計(jì)出代碼大概的結(jié)構(gòu),這樣在寫(xiě)的時(shí)候才會(huì)思路清晰。在埋點(diǎn)數(shù)據(jù)中,性能分析和錯(cuò)誤監(jiān)聽(tīng)可能會(huì)復(fù)雜一點(diǎn)。性能分析可以使用performance.timing
performance
的每一個(gè)屬性的作用節(jié)點(diǎn)可參考下圖:
錯(cuò)誤監(jiān)聽(tīng)可參考文章:如何監(jiān)聽(tīng)Vue項(xiàng)目報(bào)錯(cuò)的4種方式
完整代碼
class StatisticsSDK { constructor() { this.initPerformance(); // 性能分析 this.initError(); // 錯(cuò)誤監(jiān)聽(tīng) } // 初始化性能分析 initPerformance() { const url = 'xxx'; this.send(url, performance.timing) } // 初始化錯(cuò)誤監(jiān)聽(tīng) initError() { window.addEventListener('error', event => { const {error, lineno, colno} = event; this.error(error, {lineno, colno}) }) // Promise 未catch的錯(cuò)誤 window.addEventListener('unhandledrejection', event => { this.error(new Error(event.reason), {type: 'unhandledrejection'}) }) } // 發(fā)送埋點(diǎn)數(shù)據(jù),作為公共方法被調(diào)用 send(url, params = {}) { params.id = Date.now(); // 當(dāng)前時(shí)間戳 const arr = []; for (let key in params) { arr.push(`${key}=${params[key]}`); } const newUrl = `${url}?${arr.join('&')}`; // 參數(shù)拼接在請(qǐng)求地址上 // 使用img發(fā)送埋點(diǎn)數(shù)據(jù) // const img = new Image(); // img.src = newUrl; const img = document.createElement('img'); img.src = newUrl; } // 頁(yè)面訪問(wèn)量 pv() { const url = 'xxxx' // 調(diào)用send發(fā)送 this.send(url, {key: 'pv', value: location.href}) } // 自定義事件 event(key, value) { const url = 'xxxx'; // 服務(wù)端地址 // 調(diào)用send發(fā)送 this.send(url, {key, value}) } // 未捕獲的錯(cuò)誤,或者用戶自行發(fā)送錯(cuò)誤埋點(diǎn)數(shù)據(jù)時(shí) error(error, info = {}) { const url = 'xxx'; const {message, stack} = error; this.send(url, {message, stack, ...info}) } } const s = new StatisticsSDK();
總結(jié)
本文主要使用img來(lái)實(shí)現(xiàn)埋點(diǎn)數(shù)據(jù)的發(fā)送,考慮了跨域、兼容性,但是也存在比較大的缺陷:如果用戶禁用網(wǎng)頁(yè)加載圖片,那么將無(wú)法正常發(fā)送埋點(diǎn)數(shù)據(jù)。這種情況下,可以使用script實(shí)現(xiàn)本案例,兩者的差異可以參考詳解JavaScript發(fā)送埋點(diǎn)請(qǐng)求的兩種方式,可以使用script實(shí)現(xiàn)本案例。
到此這篇關(guān)于JavaScript利用img實(shí)現(xiàn)前端頁(yè)面埋點(diǎn)功能的文章就介紹到這了,更多相關(guān)JavaScript埋點(diǎn)功能內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Javascript實(shí)現(xiàn)Array和String互轉(zhuǎn)換的方法
這篇文章主要介紹了Javascript實(shí)現(xiàn)Array和String互轉(zhuǎn)換的方法,涉及JavaScript中toString方法與split方法的使用技巧,需要的朋友可以參考下2015-12-12js實(shí)現(xiàn)本地持久化存儲(chǔ)登錄注冊(cè)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)本地持久化存儲(chǔ)登錄注冊(cè),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08js對(duì)象屬性名駝峰式轉(zhuǎn)下劃線的實(shí)例代碼
這篇文章主要介紹了js對(duì)象屬性名駝峰式轉(zhuǎn)下劃線的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09JS生成不重復(fù)的隨機(jī)數(shù)組的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇JS生成不重復(fù)的隨機(jī)數(shù)組的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07純javascript實(shí)現(xiàn)分頁(yè)(兩種方法)
有的時(shí)候頁(yè)面需要很多不同的表組成的數(shù)據(jù),該怎么分頁(yè)呢?使用數(shù)據(jù)庫(kù)分頁(yè)很簡(jiǎn)單,那么如何使用js實(shí)現(xiàn)分頁(yè)呢?接下來(lái),小編幫大家解決這個(gè)問(wèn)題,需要的朋友一起來(lái)學(xué)習(xí)吧2015-08-08HTML5+Canvas調(diào)用手機(jī)拍照功能實(shí)現(xiàn)圖片上傳(上)
這篇文章主要為大家詳細(xì)介紹了HTML5+Canvas,和jquery技術(shù),調(diào)用手機(jī)拍照功能實(shí)現(xiàn)圖片上傳,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04