JavaScriptで、同じドメインを2回以上クリックしたユーザーを見つける方法はありますか?
ユーザーがサイトの任意の場所を 3 回クリックした後、ウィンドウをポップアップする必要があります。ワンクリックでそれを行う方法を知っています -document.referrer
またはaddEventListener
を使用しますが、その後は迷ってしまいます。
リンクだけでなく、すべてのクリックイベントをキャプチャしてカウントするものが必要です。
JavaScriptで、同じドメインを2回以上クリックしたユーザーを見つける方法はありますか?
ユーザーがサイトの任意の場所を 3 回クリックした後、ウィンドウをポップアップする必要があります。ワンクリックでそれを行う方法を知っています -document.referrer
またはaddEventListener
を使用しますが、その後は迷ってしまいます。
リンクだけでなく、すべてのクリックイベントをキャプチャしてカウントするものが必要です。
もちろん。ユーザーのクリック イベントのリストを、Cookie またはサーバー側のデータ ストアに保存する必要があります。記録されたクリックごとに、カウントを 1 ずつ増やし、数が 3 に達したときに実行します。
セッション Cookie を使用してページ間の状態を保存してみてください。セッション Cookie は高速で、互換性が非常に広く、ユーザーの Cookie jar をスパム送信しないように、ブラウザーがシャットダウンするとゼロになります。
私はこれを試してみましたが、うまくいきました:
window.onload = function() {
var clicked = readCookie('popunder');
if(clicked == null) {
clicked = 0;
}
var allLinks = document.getElementsByTagName("a");
for(i=0;i<=allLinks.length;i++) {
allLinks[i].addEventListener("click",countClicks,true);
}
function countClicks() {
if(clicked == 2) {
popunder(); //something to do
} else {
clicked++;
doCookie('popunder', clicked, 1);
alert(clicked);
}
}
function popunder() { alert('thats 3 clicks!'); }
function doCookie(name,value,days) {
if (days) {
var date = new Date();
date.setTime(date.getTime()+(days*24*60*60*1000));
var expires = "; expires="+date.toGMTString();
} else {
var expires = "";
}
document.cookie = name+"="+value+expires+"; path=/";
}
function readCookie(name) {
var readName = name + "=";
var cSplit = document.cookie.split(';');
for(var i=0;i < cSplit.length;i++) {
var sc = cSplit[i];
while (sc.charAt(0)==' ') sc = sc.substring(1,sc.length);
if (sc.indexOf(readName) == 0) return sc.substring(readName.length,sc.length);
}
return null;
}
}
アドバイスありがとうございます。このコードを試しました。しかし、更新後、クリックされた変数は再び 0 になります。クリックされたすべての新しい値を Cookie (またはその他のもの)に保存する必要があるため、ページ上のリンクをクリックするたびにその数が増加します。このようにクッキーの変数の値を変更することは可能ですか?
window.onload = function(){
var **allLinks** = document.getElementsByTagName("a");
var **clicked** = 0;
**doCookie**('popunder',clicked,1);
for(i=0;i<=allLinks.length;i++){
allLinks[i].addEventListener("click",countClicks,true);
}
function **countClicks**(){
if(clicked == 3){
popunder(); //something to do
}
else{
alert(readCookie('popunder'));
return clicked++;
}
}
function **doCookie**(name,value,days) {
if (days) {
var date = new Date();
date.setTime(date.getTime()+(days*24*60*60*1000));
var expires = "; expires="+date.toGMTString();
}
else var expires = "";
document.cookie = name+"="+value+expires+"; path=/";
}
function **readCookie**(name) {
var readName = name + "=";
var cSplit = document.cookie.split(';');
for(var i=0;i < cSplit.length;i++) {
var sc = cSplit[i];
while (sc.charAt(0)==' ') sc = sc.substring(1,sc.length);
if (sc.indexOf(readName) == 0) return sc.substring(readName.length,sc.length);
}
return null;
}