javascript - 網站拿到使用者的瀏覽軌跡,按鈕點擊,表單填寫相關行為資料的比較好的方式是什麼?
這是今天面試的一道面試題,自己想到的比較簡單的是透過 cookie 記錄使用者的相關數據,然後當網頁關閉的時候再發送會服務端。
網上搜了下 百度統計, GA 的相關資料,貌似也是通過 cookie 記錄相關信息,保存數據是通過請求一張圖片然後帶上不同的參數來實現的。
不知道大家有沒有其他的好方法。
回覆內容:
這是今天面試的一道面試題,自己想到的比較簡單的是透過 cookie 記錄使用者的相關數據,然後當網頁關閉的時候再發送會服務端。
網上搜了下 百度統計, GA 的相關資料,貌似也是通過 cookie 記錄相關信息,保存數據是通過請求一張圖片然後帶上不同的參數來實現的。
不知道大家有沒有其他的好方法。
我不多說了,你自己意會
<code>var _hmt = _hmt || []; /* 指定要响应JS-API调用的帐号的站点id */ //_hmt.push([ '_setAccount', 'XXXXXXXX' ]); // 用于发送某个指定URL的PV统计请求,通常用于AJAX页面的PV统计。 // _hmt.push(['_trackPageview', pageURL]); // 用于触发某个事件,如某个按钮的点击,或播放器的播放/停止,以及游戏的开始/暂停等。 // _hmt.push(['_trackEvent', category, action, opt_label, opt_value]); // 用户访问一个安装了百度统计代码的页面时,代码会自动发送该页面的PV统计请求,如果不希望自动统计该页面的PV,就可以使用本接口。主要用于iframe嵌套页面等情况。 // _hmt.push(['_setAutoPageview', false]); (function() { //加载百度的统计代码 var hm = document.createElement("script"); hm.src = "//hm.baidu.com/hm.js?XXXXXXX"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); (function() { function doMonitorForDataTrack(target) { var target = target; var _track = target.getAttribute("data-track"); if (typeof (_hmt) != "undefined" && _track != '') { if (_track.indexOf("_hmt.push") > -1) { eval(_track); } else { var _trackArr = _track.split('.'); if (_trackArr.length < 2) return; var category = 'Click';// 必填项,参数为字符串 var action = '';// 必填项,参数为字符串 var label = '';// 可选,参数为字符串 /**当只有一个分割字符, * 例如 data-track="index.10001",执行函数 _hmt.push(['_trackEvent', 'Click', 'index', '10001‘]) * */ if (_trackArr.length == 2) { category = 'Click'; action = _trackArr[0];// 必填项,参数为字符串 label = _trackArr[1];// 可选,参数为字符串 } /**当有超过两个或两个以上分割字符, * 如 data-track="songli.BTN.担保交易",执行_hmt.push(['_trackEvent', 'songli', 'BTN', '担保交易‘]); * 如 data-track="songli.BTN.担保交易.1002" ,执行_hmt.push(['_trackEvent', 'songli', 'BTN', '担保交易.1002‘]); * */ else { category = _trackArr.shift();// 必填项,参数为字符串 action = _trackArr.shift();// 必填项,参数为字符串 label = _trackArr.join('.');// 可选,参数为字符串 } _hmt.push([ '_trackEvent', category, action, label ]); } } } function addEvent(obj, type, fn) { if (obj.attachEvent) { obj['e' + type + fn] = fn; obj[type+fn] = function(){obj['e'+type+fn]( window.event );} obj.attachEvent('on' + type, obj[type + fn]); } else obj.addEventListener(type, fn, false); } var _elemArr = document.getElementsByTagName('A'), _elemLen = _elemArr.length; var _body = document.body || document.documentElement; addEvent(_body, "click", function(event) { var event = event ? event : window.event; var target = event.srcElement ? event.srcElement : event.target; if (target.getAttribute('data-track')){ doMonitorForDataTrack(target); } else if (target.nodeName == "IMG" && target.parentNode.getAttribute('data-track')) { doMonitorForDataTrack(target.parentNode); } }); })();</code>
瀏覽軌跡,按鈕點選可以再服務端寫到mongo裡頭,表單js監聽dom了
這些個統計存在Cookie裡面的一般只是一些用來辨識使用者的ID值吧。使用者的操作記錄資料應該是立刻送到統計伺服器上去的,沒必要在本地保存一下再發送,這類的資料量很少,不會造成壅塞。至於怎麼發送過去,大部分都是採用你所理解的簡單的加載一個圖片,透過參數把資料傳上去。
“當網頁關閉的時候再發送會服務端”,這個是有問題額,瀏覽器關閉的時候你的JS基本上沒法任何事情了。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。
