欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

小程序從手動埋點到自動埋點的實現(xiàn)方法

 更新時間:2019年01月24日 14:11:47   作者:蟹老板愛寫代碼  
這篇文章主要介紹了小程序從手動埋點到自動埋點的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

小程序由于封閉性較強,要像web應(yīng)用一樣實現(xiàn)靈活的數(shù)據(jù)收集,會有一定難度。目前開源的埋點SDK,一般采用手動埋點的方式,這種方式有較強的侵入型,為了解決這個問題就有了該文章。

手動埋點

以騰訊移動分析的SDK為例,如果要記錄埋點信息,只要插入一句代碼即可

// 例如,記錄搜索行為
search(keyword) {
  if (keyword) {
    ...業(yè)務(wù)代碼
  }
  mta.Event.stat("ico_search", {"query":keyword});
}

示例代碼看起來是比較簡潔的,但是埋點需要收集的數(shù)據(jù)往往不是單一的,復(fù)雜的埋點代碼插入業(yè)務(wù)代碼,會 影響代碼的閱讀體驗 ,而且 埋點代碼散落在各個地方,不方便管理 。

由于手動埋點必須插入到函數(shù)中,有時候我們?yōu)榱双@取頁面某一元素點擊信息,產(chǎn)生了一種叫無業(yè)務(wù)相關(guān)埋點,簡單來說就是你的函數(shù)定義,就只有埋點代碼,當(dāng)這種埋點頻繁出現(xiàn), 代碼會被嚴(yán)重污染 。

// wxml
<view bindtap="track">這只是一個展示view</view>
//js 
track() {
 mta.Event.stat("eleClick", {"name":xxxxx});
}

另外,由于PM會頻繁調(diào)整埋點信息,而 埋點是一個繁瑣又無聊的工作 ,基于Don't Repeat Yourself 原則,手動埋帶要不得。

總結(jié)以上,手動埋點有下列問題

  • 影響代碼的閱讀體驗
  • 埋點代碼散落在各個地方,不方便管理
  • 代碼會被污染
  • 埋點是一個繁瑣又無聊的工作

自動埋點

實現(xiàn)思路:監(jiān)聽用戶點擊-->讀取埋點配置JOSN,判斷是否需要上報--> 上報數(shù)據(jù)

1、小程序監(jiān)聽用戶點擊行為

web應(yīng)用監(jiān)聽用戶點擊行為是比較容易,但是小程序沒有提供Dom的事件監(jiān)聽,不過我們可以通過事件冒泡的方式捕獲。

// web監(jiān)聽頁面點擊
document.addEventListener('click',(e) => {console.log(e)})

// 小程序監(jiān)聽頁面點擊,用戶的點擊行為都會執(zhí)行elementTracker方法
<view catchtap='elementTracker'>
 <view class='buy-now'>
   <button bindtap='buy' animation="{{scaleAnim}}">立即購票</button>
 </view>
</view>

2、判斷點擊位置是否落在監(jiān)聽元素中

假設(shè)需要監(jiān)聽用戶是否點擊class為buy-now元素,可以通過獲取buy-now元素長寬,定位和點擊位置坐標(biāo)判斷是否出現(xiàn)重疊,以判斷是否被點擊。

/**
 * 判斷點擊是否落在目標(biāo)元素
 * @param {Object} clickInfo 用戶點擊坐標(biāo)
 * @param {Object} boundingClientRect 目標(biāo)元素信息
 * @param {Object} scrollOffset 頁面位置信息
 * @returns {Boolean}
 */
export const isClickTrackArea = function (clickInfo, boundingClientRect, scrollOffset) {
  if (!boundingClientRect) return false;
  const { x, y } = clickInfo.detail; // 點擊的x y坐標(biāo)
  const { left, right, top, height } = boundingClientRect;
  const { scrollTop } = scrollOffset;
  if (left < x && x < right && scrollTop + top < y && y < scrollTop + top + height) {
    return true;
  }
  return false;
};

3、通過配置表聲明埋點

為了解決代碼入侵問題,可以將所有埋點信息統(tǒng)一管理,通過配置表的方式,除了方便管理,以后還可以做到動態(tài)配置,在服務(wù)端配置完畢下發(fā)到客戶端。

const tracks = {
 path: 'pages/film/detail',
 elementTracks: [
  {
   element: '.buy-now', // 聲明需要監(jiān)聽的元素
   dataKeys: ['film.filmId'], // 聲明需要獲取Data下的哪些數(shù)據(jù)
  },
 ]
};

4、對頁面函數(shù)埋點

有些場景我們除了對頁面元素點擊埋點,還要對頁面函數(shù)進行埋點,例如用戶下拉刷新的時候,可以對原方法進行包裝,插入埋點代碼。

rewritePage() {
  const originPage = Page;
  Page = (page) => {
   Object.keys(page).forEach((methodName) => {
    // 執(zhí)行埋點邏輯
    typeof page[methodName] === 'function' && this.recordPageFn(page, methodName);
   });
   // 執(zhí)行原Page對象
   return originPage(page);
  };
 }

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • google地圖的路線實現(xiàn)代碼

    google地圖的路線實現(xiàn)代碼

    google地圖的路線實現(xiàn)代碼,大家可以參考下,實現(xiàn)自己想要的功能。
    2009-08-08
  • 使用apifm-wxapi快速開發(fā)小程序過程詳解

    使用apifm-wxapi快速開發(fā)小程序過程詳解

    這篇文章主要介紹了使用apifm-wxapi快速開發(fā)小程序過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • js檢測判斷日期大于多少天的方法

    js檢測判斷日期大于多少天的方法

    這篇文章主要介紹了js檢測判斷日期大于多少天的方法,涉及javascript操作日期的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-05-05
  • js判斷瀏覽器類型的方法

    js判斷瀏覽器類型的方法

    這篇文章介紹了js判斷瀏覽器類型的方法,有需要的朋友可以參考一下
    2013-08-08
  • 18個高頻使用的JS工具方法總結(jié)

    18個高頻使用的JS工具方法總結(jié)

    這篇文章主要為大家分享一下18個在項目中使用很高頻的JS工具方法,希望大家能夠知其然也知其所以然,不要只會調(diào)用?api,也要會寫?api,快跟隨小編一起學(xué)習(xí)一下吧
    2022-04-04
  • JavaScript 特有方法計算二進制中1的個數(shù) split方法

    JavaScript 特有方法計算二進制中1的個數(shù) split方法

    這是一道網(wǎng)上看到的前端的筆試題,主要思想是利用JavaScript的toString方法將十進制數(shù)轉(zhuǎn)換為二進制的字符串。然后for循環(huán)遍歷計算字符串中”1″出現(xiàn)的次數(shù)。
    2010-05-05
  • js中遍歷Map對象的方法

    js中遍歷Map對象的方法

    下面小編就為大家?guī)硪黄猨s中遍歷Map對象的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • 關(guān)于JS中match() 和 exec() 返回值和屬性的測試

    關(guān)于JS中match() 和 exec() 返回值和屬性的測試

    這篇文章主要介紹了關(guān)于JS中match() 和 exec() 返回值和屬性的測試 的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • 微信小程序開發(fā)之全局配置與頁面配置實現(xiàn)

    微信小程序開發(fā)之全局配置與頁面配置實現(xiàn)

    本文主要介紹了微信小程序開發(fā)之全局配置與頁面配置實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • js實現(xiàn)網(wǎng)頁收藏功能

    js實現(xiàn)網(wǎng)頁收藏功能

    這篇文章主要介紹了js實現(xiàn)動態(tài)添加或刪除網(wǎng)址功能,以及js實現(xiàn)網(wǎng)頁收藏功能,感興趣的小伙伴們可以參考一下
    2015-12-12

最新評論