目前主流的埋點方案包括javascript
在須要埋點的節點調用接口,攜帶數據上傳。如百度統計等;html
缺點前端
工做量較大,每個組件的埋點都須要添加相應的代碼,入侵業務代碼,增長項目複雜度。vue
經過可視化交互的手段,代替代碼埋點。將業務代碼和埋點代碼分離,提供一個可視化交互的頁面,輸入爲業務代碼,經過這個可視化系統,能夠在業務代碼中自定義的增長埋點事件等等,最後輸出的代碼耦合了業務代碼和埋點代碼。java
可視化埋點聽起來比較高大上,實際上跟代碼埋點仍是區別不大。也就是用一個系統來實現手動插入代碼埋點的過程。ios
缺點:服務器
業務屬性數據,例如,訂單號、金額、商品數據量等,一般要調用後臺的接口,可視化埋點在這方面的支持有限;框架
須要藉助第三方工具實現。ide
無埋點並非說不須要埋點,而是所有埋點,前端的任意一個事件都被綁定一個標識,全部的事件都別記錄下來。經過按期上傳記錄文件,配合文件解析,解析出來咱們想要的數據,並生成可視化報告供專業人員分析所以實現「無埋點」統計。
缺點函數
沒法靈活的定製各個事件所須要上傳的數據
無埋點採集全量數據,給數據傳輸和服務器增長壓力
代碼埋點分爲 命令式埋點和聲明式埋點
顧名思義,開發者須要手動在須要埋點的節點處進行埋點。如點擊按鈕或連接後的回調函數、頁面ready時進行請求的發送。你們確定都很熟悉這樣的代碼:
// 頁面加載時發送埋點請求 $(document).ready(function(){ // ... 這裏存在一些業務邏輯 sendRequest(params); }); // 按鈕點擊時發送埋點請求 $('button').click(function(){ // ... 這裏存在一些業務邏輯 sendRequest(params); });
聲明式埋點對命令式埋點作了改進,將埋點的代碼與具體的業務邏輯解耦。從而提升埋點的效率和代碼的可維護性。代碼以下:
// key表示埋點的惟一標識;act表示埋點方式 <button v-log="{caption:'登陸頁', paras: '用戶點擊驗證碼發送'}">發送驗證碼</button>
由於項目採用Vue框架,因此使用Vue中的自定義指令完成聲明式埋點。
Vue.directive('log', { bind( el, binding ){ el.addEventListener('click', ()=>{ Axios.post }) } });
只須要在須要記錄的組件中配置使用v-log指令,加上詳情參數就能夠完成用戶軌跡記錄。以下:
// caption表示埋點的模塊;paras表示用戶的行爲 <button v-log="{caption:'登陸頁', paras: '用戶點擊驗證碼發送'}">發送驗證碼</button>