タブアンダー広告をjQueryで再現する方法
2024/01/13
サイト内のリンクをクリックすると、新しいタブもしくはウィンドウで開く広告をちょいちょい見るけど、どういう仕組みになっているのか気になった。以下に方法のメモ。
再現したいこと
- サイト内のリンクをクリックするとタブアンダーで指定したURLを開く。javascript:void(0)みたいなリンクは開かない。
- クリックすると以降○時間はタブアンダーは開かない。○時間の部分は任意で設定可能。
ソース
(function($){
$.fn.popad = function(options){
var defaults = {
url : '',
limit : 1
};
var setting = $.extend(defaults, options);
if( setting.url == '' ){
return false;
}
if( setting.limit < 1 || setting.limit > 24 ){
setting.limit = 1;
}
//cookieの処理
var flg = true;
var all_cookies = document.cookie;
if( all_cookies != '' ){
var cookies = all_cookies.split('; ');
for( var i = 0; i < cookies.length; i++ ){
var cookie = cookies[ i ].split('=');
if( cookie[0] == 'popad' ){
flg = false;
}
}
}
//aタグクリック
jQuery('a').click(function(){
var click_url = $(this).attr('href');
if( !click_url.match(/(http|https):\/\/.+/) ){
return false;
}
if( flg ){
var expire = new Date();
expire.setTime( expire.getTime() + 1000 * 3600 * setting.limit );
document.cookie = 'popad=1; path=/; expires=' + expire.toUTCString();
window.location.href = setting.url;
window.open($(this).attr('href'));
return false;
}
});
}
})(jQuery);
※使用される場合は自己責任でお願いします。
サンプル
https://taitan916.info/sample/popad/
使い方
jQueryと一緒に読み込む。以下でURLと時間を指定する。
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script type="text/javascript" src="./jquery.popad.js"></script>
<script>
$(function(){
$().popad({
url : 'http://yahoo.co.jp', //別タブで開かせたいURL。指定しない場合はタブは開かず。
limit : 1 //有効時間設定。1~24時間までで整数値。デフォルトは1時間
});
});
</script>
その他
動作は多分再現できたはず。ただアフィリエイトとかだと相手先から許可は出なさそう。というかペナルティを喰らいそう。
関連記事
-
-
jQuery UIを使って簡単にダイアログを表示させる方法
ブラウザ上でユーザーに対してちょっとした確認を行いたい場合はJavaScript ...
-
-
Jcropを使ってブラウザ上で画像を範囲指定して切り抜き(トリミング)
やりたかった事は、画像をアップロードして必要な部分のみを範囲指定してもらい、指定 ...
-
-
jQueryの「DateTimePicker」プラグインで日付や時間選択時に指定したイベントを実行させる方法
jQueryの「DateTimePicker」プラグインで日付や時間選択時、あら ...
-
-
Ajaxを使用する際の注意
Ajaxで特にJSONPを使う際によくミスることがあるので 注意点をまとめておく ...
-
-
jQueryで画像(
タグ内)のsrc情報を取得する場合
すぐに出てこなかったのでメモ。 $('#test').attr('src'); ...