tips

クッキーを使わずにjavascriptで初回アクセスかどうかを判別する。

first_time_user_or_not

特定ページへの初回訪問かどうかを見分ける

jQueryなどを使って初回訪問時のみアクションを加えたい。でもクッキーなんて使いたくない。

…という場合には、ウインドウ名を利用して簡易的に判断する方法が有効です。javascriptで表示中のURLからファイル名(ベースのスラッグ)を取得し、ウインドウ名に加える処理を行います。

verify first time visitor or not

<script type="text/javascript">

    //verify first time visitor or not in the pages
    var $currentpath = window.location.pathname.replace(///, '').replace(/./, '').replace(/_/, '-'); // 表示中のページのファイル名を取得する
    if ( !$currentpath ) $currentpath = "homepage"; // トップページ(ファイル名が存在しない場合)に登録する任意のファイル名
    if ( window.name.indexOf( '#' + $currentpath )!=-1 ) { //ウィンドウ名に現在のファイル名が含まれるかチェック
        alert( "I've seen you before!" ); // リロードや2度目以降の訪問時の処理
    } else { 
        window.name = window.name + '#' + $currentpath; // ウィンドウ名の末尾にファイル名を追加する、#はエスケープ処理
        alert( "It's nice to see you!" ); // 初回訪問時の処理
    }

</script>

チェックしたいページ全てに記述する必要があります。ウインドウ名を利用しているので別窓で開くと無効になります。

なお、ウインドウ名には文字数制限(255文字かな?)があるはずなので、動的サイトで全体のアクセス履歴を書き込んでいくのは無理があります。また、ウィンドウ名に指定できるのは半角英数字のみです。なのでwordpressなどのCMSに埋め込むなら、トップページや固定ページ内だけなどに絞って、何かアクションさせたいときに使いましょう。wordpressなどのCMSで埋め込むなら、ページテンプレートやホームテンプレート内で使用し、らpathnameを取得する手続きをカットし、直接phpでpost IDを使った名前を代入する方が、処理も早くて文字数も抑えられます。以下はWPで実際に私が使ってる感じに近いもの。

var currentid = <?php echo "'p$post->ID#'"; ?>; // #はエスケープ処理
if ( window.name.indexOf( currentid ) == -1 ) { // 初アクセス 
    window.name = window.name + currentid; // ウィンドウ名の末尾にファイル名を追加する
    //以下処理が続く
}

 

そもそもユーザーがホームページへの初回訪問かどうかを判別する場合

おまけ。

ニュースなどのウインドウをポップアップしたいときなど、すべてのページでユーザーが初回訪問かどうか有効にしたいときもあります。この場合、チェックしたい各ページ全てに記述する必要があります。

<script type="text/javascript">

    //verify first time visitor or not in the site
    var $my_window = "my_homepage"; // 任意のウィンドウ名を指定
    if ( window.name.indexOf( $my_window )!=-1 ) { //任意のウインドウ名かチェック
        alert( "I've seen you before!" ); // 2度目以降の訪問時の処理
    } else { 
        window.name = $my_window; // ウィンドウ名を任意に名付ける
        alert( "It's nice to see you!" ); // 初回訪問時の処理
    }

</script>

とにかく外部からのアクセス時の一回だけでいい、という場合は以下のようにシンプルに処理する方法もあります。リファラを見ているので、別ウインドウで開いても大丈夫ですし、該当するページ一箇所に記述するだけで済みます。しかしスクリプトの設置の有無で判別できないので、サブディレクトリ以下でのみチェックをしたい場合には不向きです。

<script type="text/javascript">

    //verify first time visitor or not in the site
    
    if( document.referrer.indexOf( "//example.com" )!=-1 ) {  { //リファラにアドレスが含まれているか。
        alert( "I've seen you before!" ); // 2度目以降の訪問時の処理
    } else { 
        alert( "It's nice to see you!" ); // 初回訪問時の処理
    }

</script>

「ImageLightbox.js:カスタマイズしやすい軽量ライトボックス」への1件の返信

  1. はじめまして。

    Image Lightboxをサイトに使用してカスタマイズしようとして、つまずいてます。。
    captionの位置が固定なんですよね…。これを写真の真下あるいは真上に移動させたいのですが、どうにもこうにも…
    わかる人にはすぐわかるのでしょうがどうも知識不足で困っています…

    1. CSSだけでは実現できません。

      まず、imagelightbox.jsの60行目くらいにあるオプションのcaptionHeight周辺にでも、idとポジションの項目を追加して下さい。

      captionid: 'imagelightboxcaption',
      captionHeight: 0,
      captionPosi: 'bottom', // 'bottom','top','image-bottom','image-top'

      次に107行目当たりのimageへのcss指定を丸ごと以下の様に変更します。

       

      var caption = $( '#' + options.captionid );
      if( caption.length ){
      if ( !options.captionHeight ) {
      options.captionHeight = caption.outerHeight();
      }
      if ( options.captionPosi == 'image-bottom' ) {
      caption.css({
      'width':  imageWidth + 'px',
      'top': ( $( window ).height() - options.captionHeight - imageHeight ) / 2 + imageHeight + 'px'
      });
      } else if ( options.captionPosi == 'image-top' ) {
      caption.css({
      'width':  imageWidth + 'px',
      'top': ( $( window ).height() - options.captionHeight - imageHeight ) / 2 + 'px'
      });
      }
      }
      
      image.css(
      {
      'width': imageWidth + 'px',
      'height': imageHeight + 'px',
      'top': ( $( window ).height() + ( ( options.captionPosi == 'top' || options.captionPosi == 'image-top' )? options.captionHeight: options.captionHeight * (-1) ) - imageHeight ) / 2 + 'px',
      'left': ( $( window ).width() - imageWidth ) / 2 + 'px'
      });

      これで準備は完了。あとはinstanceに captionPosi:’image-bottom’, captioned:’my-caption-id’ みたいな感じで自由に設定して下さい。captionPosiはデフォルトがbottomです。ウィンドウの最上部に指定する場合はtop、画像のすぐ上と下に配置する場合はimage-topとimage-bottomを指定します。
      cssはimagelightboxの仕様に習って、js側では最低限しか指定していませんので注意して下さい。captionにする要素にはposition:fixedとleft:0, right:0は必要だと思います。あとできればmargin-right:auto, margin-left:autoやborder-box を与えておいて下さい。ただし、ie8で動くかどうかはしりません。あしからず。

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です