關(guān)于小程序開發(fā)的經(jīng)驗(yàn)以及過程中遇到的“坑”在我們團(tuán)隊(duì)之前的小程序開發(fā)經(jīng)驗(yàn)系列文章中已經(jīng)介紹的差不多了,大數(shù)據(jù)時 ...
關(guān)于小程序開發(fā)的經(jīng)驗(yàn)以及過程中遇到的“坑”在我們團(tuán)隊(duì)之前的小程序開發(fā)經(jīng)驗(yàn)系列文章中已經(jīng)介紹的差不多了,大數(shù)據(jù)時代,一個產(chǎn)品成敗的背后需要用大量的數(shù)據(jù)去分析驗(yàn)證。本期就和大家一起探索下,微信小程序是如何進(jìn)行數(shù)據(jù)采集與分析的,當(dāng)然還有過程中的“坑”。
本文部分示例來自于「大眾點(diǎn)評點(diǎn)餐」小程序的菜單頁面。
所有內(nèi)容基于2017年3月2日為止的官方api
微信小程序公眾平臺目前提供了一套官方的數(shù)據(jù)采集分析平臺。
官方api:https://mp.weixin.qq.com/debug/wxadoc/analysis/index.html?t=201726
就目前小程序公測版官方提供了以下幾種數(shù)據(jù)分析:
具體數(shù)據(jù)可通過https://mp.weixin.qq.com 使用小程序管理員賬號登錄之后查看。
前3種方式都是小程序自動采集,不需要開發(fā)者任何的人為操作,在微信官方文檔中都有詳細(xì)說明了,這邊就不再闡述
本文主要結(jié)合「大眾點(diǎn)評點(diǎn)餐」小程序來看下第4種-自定義分析能做什么
自定義分析就是傳統(tǒng)意義上的埋點(diǎn),用戶可以自行設(shè)置希望上報的數(shù)據(jù),通過這些數(shù)據(jù)來分析你希望得到的結(jié)果。
微信官方的自定義分析使用了當(dāng)下比較流行的無埋點(diǎn)技術(shù),通過微信后臺配置錨點(diǎn)并實(shí)時下發(fā)到客戶端生效,無需在代碼中手動加入埋點(diǎn)代碼,并且由于小程序發(fā)版有審核機(jī)制,如果手動埋一次點(diǎn)就需要重新提審,成本將會非常高,所以采用無埋點(diǎn)技術(shù)是非常適合于小程序的場景。
但從目前「大眾點(diǎn)評點(diǎn)餐」小程序中測試下來,目前內(nèi)測版本的自定義分析(截止2017年3月2日)對代碼本身設(shè)計與書寫的要求比較苛刻,數(shù)據(jù)采集需要與頁面page的data做到關(guān)聯(lián),在某些場景下會出現(xiàn)比較難以滿足的情況。
接下來讓我們看看實(shí)現(xiàn)一個自定義事件的步驟:
click 點(diǎn)擊時觸發(fā),必須指定page和element
enterPage 進(jìn)入頁面時觸發(fā),必須指定page
leavePage 離開頁面時觸發(fā),必須指定page
pullDownRefresh 下拉刷新時觸發(fā),必須指定page
launch 加載小程序時觸發(fā)
background 切換到后臺觸發(fā)
foreground 切換到前臺觸發(fā)
share 分享時觸發(fā)
action trigger發(fā)生時的動作,默認(rèn)會收集數(shù)據(jù),包括系統(tǒng)默認(rèn)數(shù)據(jù)和用戶自定義數(shù)據(jù)(data中定義)
空 只收集數(shù)據(jù);
start 初始化并收集數(shù)據(jù);
report 收集數(shù)據(jù)并上報事件數(shù)據(jù)
start_and_report 初始化,收集數(shù)據(jù)后上報;
注:每次report之前必須有start操作,未經(jīng)過start操作是不會上報的。
對于一個動作,如果設(shè)置了start_and_report,且指定了click觸發(fā)條件,則時序如下:
click event -> start -> 收集數(shù)據(jù) ->report
page 觸發(fā)的頁面, 如pages/index/index, pages/list/list,此規(guī)則與小程序app.json的pages字段保持一致, 如果需要任意頁面觸發(fā),則填寫ANY_PAGE。
element 觸發(fā)的元素,支持一層級的css的id和class選擇器,即必須以’.’或者’#’開頭
data 收集的自定義數(shù)據(jù),為0到多項(xiàng), 每一項(xiàng)都是以 “字段名 字段值”的方式;如果不填,則只收集系統(tǒng)數(shù)據(jù)。
字段名:事件里的字段名
字段值:事件這個字段的數(shù)據(jù)值,填寫頁面上的變量名(即page實(shí)例的data字段),可以搜集頁面上的變量;如果data收集的是數(shù)組里的某一項(xiàng)數(shù)據(jù)(如list[].id),則根據(jù)當(dāng)前觸發(fā)元素是由class得到的NodeList的第幾個來決定數(shù)組下標(biāo)。
除此之外,還可以填寫一些提供的系統(tǒng)屬性,以“$”開頭,目前支持以下屬性:
$PAGE_TIME 用戶從進(jìn)入本頁面到當(dāng)前的時間(觸發(fā)action的時間點(diǎn))
$APP_TIME 用戶進(jìn)入小程序到當(dāng)前的時間(觸發(fā)action的時間點(diǎn))
$CURRENT_PAGE 當(dāng)前用戶所在的頁面
$LAST_PAGE 上一頁
注:data可以為空,為空時該事件上報僅收集系統(tǒng)默認(rèn)字段的數(shù)據(jù)
——————————————————————————————————
注意下我標(biāo)紅的關(guān)于data的value的解釋,這個value就是之前說的「大眾點(diǎn)評點(diǎn)餐」小程序中某些場景下難以滿足采集需求的原因
我們先來繼續(xù)完成這個事件,等下再來回頭說說這個data的坑。
接下來,回到剛才提到的data的value這個值,認(rèn)真閱讀這行文字你會發(fā)現(xiàn)幾個重點(diǎn):
其中第二點(diǎn)舉個例子:
由于小程序中不支持cookie,而公司的統(tǒng)計系統(tǒng)有部分?jǐn)?shù)據(jù)的發(fā)送是通過cookie來實(shí)現(xiàn)的,后續(xù)可以考慮將所有數(shù)據(jù)手動在代碼中埋點(diǎn),然后通過ajax方式來發(fā)送到公司的統(tǒng)計datebase中,由公司自己的統(tǒng)計系統(tǒng)來完全對小程序的統(tǒng)計。