亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript利用img實現前端頁面埋點功能

 更新時間:2022年06月16日 08:37:37   作者:諸葛小愚  
做數據分析的時候需要獲取足量的有效數據,這個時候就需要我們在前端頁面埋點。如何來實現一個前端埋點功能,本文就帶你上手試試

做數據分析的時候,可能會遇到一個問題:如何獲取足量的有效數據。簡單記錄用戶登錄IP肯定是不能滿足要求的,這個時候就需要我們在前端頁面埋點,也就是數據采集點。如何來實現一個前端埋點功能,本文就帶你上手試試。

數據類型

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

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

埋點數據范圍清晰了,那么怎么來實現埋點呢?

技術方案

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

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

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

如何設計

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

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

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

完整代碼

    class StatisticsSDK {
    constructor() {
      this.initPerformance(); // 性能分析
      this.initError(); // 錯誤監(jiān)聽
    }
    // 初始化性能分析
    initPerformance() {
      const url = '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(new Error(event.reason), {type: 'unhandledrejection'})
      })
    }

    // 發(fā)送埋點數據,作為公共方法被調用
    send(url, params = {}) {
      params.id = Date.now(); // 當前時間戳
      const arr = [];
      for (let key in params) {
        arr.push(`${key}=${params[key]}`);
      }
      const newUrl = `${url}?${arr.join('&')}`; // 參數拼接在請求地址上
      // 使用img發(fā)送埋點數據
      // const img = new Image();
      // img.src = newUrl;
      const img = document.createElement('img');
      img.src = newUrl;
    }

    // 頁面訪問量
    pv() {
      const url = 'xxxx'
      // 調用send發(fā)送
      this.send(url, {key: 'pv', value: location.href})
    }

    // 自定義事件
    event(key, value) {
      const url = 'xxxx'; // 服務端地址
      // 調用send發(fā)送
      this.send(url, {key, value})
    }

    // 未捕獲的錯誤,或者用戶自行發(fā)送錯誤埋點數據時
    error(error, info = {}) {
      const url = 'xxx';
      const {message, stack} = error;
      this.send(url, {message, stack, ...info})
    }
  }
  const s = new StatisticsSDK();

總結

本文主要使用img來實現埋點數據的發(fā)送,考慮了跨域、兼容性,但是也存在比較大的缺陷:如果用戶禁用網頁加載圖片,那么將無法正常發(fā)送埋點數據。這種情況下,可以使用script實現本案例,兩者的差異可以參考詳解JavaScript發(fā)送埋點請求的兩種方式,可以使用script實現本案例。

到此這篇關于JavaScript利用img實現前端頁面埋點功能的文章就介紹到這了,更多相關JavaScript埋點功能內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Javascript實現Array和String互轉換的方法

    Javascript實現Array和String互轉換的方法

    這篇文章主要介紹了Javascript實現Array和String互轉換的方法,涉及JavaScript中toString方法與split方法的使用技巧,需要的朋友可以參考下
    2015-12-12
  • js鏈表操作(實例講解)

    js鏈表操作(實例講解)

    下面小編就為大家?guī)硪黄猨s鏈表操作(實例講解)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • js實現本地持久化存儲登錄注冊

    js實現本地持久化存儲登錄注冊

    這篇文章主要為大家詳細介紹了js實現本地持久化存儲登錄注冊,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • JavaScript sleep睡眠函數的使用

    JavaScript sleep睡眠函數的使用

    JavaScript是單線程運行的,沒有內置的sleep函數,那么JavaScript sleep睡眠函數是怎樣實現的,感興趣的小伙伴們可以參考一下
    2021-07-07
  • javascript數組去重的六種方法匯總

    javascript數組去重的六種方法匯總

    數組去重復是一個常見的需求,我們暫時考慮同類型的數組去重復。主要是理清思路和考慮下性能。以下方法,有各人總結也有網上熱心網友的方法,這里簡單地總結一下。
    2015-08-08
  • js對象屬性名駝峰式轉下劃線的實例代碼

    js對象屬性名駝峰式轉下劃線的實例代碼

    這篇文章主要介紹了js對象屬性名駝峰式轉下劃線的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Java前后端分離之權限管理示例分析

    Java前后端分離之權限管理示例分析

    權限管理就是管理用戶對于資源的操作。本 CRM 系統(tǒng)的權限(也稱作資源)是基于角色操作權限來實現的,即RBAC(Role-Based Access Control,基于角色的訪問控制),就是用戶通過角色與權限進行關聯
    2022-08-08
  • JS生成不重復的隨機數組的簡單實例

    JS生成不重復的隨機數組的簡單實例

    下面小編就為大家?guī)硪黄狫S生成不重復的隨機數組的簡單實例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • 純javascript實現分頁(兩種方法)

    純javascript實現分頁(兩種方法)

    有的時候頁面需要很多不同的表組成的數據,該怎么分頁呢?使用數據庫分頁很簡單,那么如何使用js實現分頁呢?接下來,小編幫大家解決這個問題,需要的朋友一起來學習吧
    2015-08-08
  • HTML5+Canvas調用手機拍照功能實現圖片上傳(上)

    HTML5+Canvas調用手機拍照功能實現圖片上傳(上)

    這篇文章主要為大家詳細介紹了HTML5+Canvas,和jquery技術,調用手機拍照功能實現圖片上傳,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04

最新評論