離脱防止ポップアップをコードで実装する方法【exit-intent対応】

離脱防止ポップアップとは、ユーザーがページを閉じようとした瞬間にオファーやメッセージを表示し、離脱を防ぐCRO施策です。exit-intentと呼ばれるマウスの動きをJavaScriptで検出して実装します。

OptinMonsterの事例では、exit-intentポップアップでメール登録率が最大600%向上したケースが報告されています。この記事では、離脱防止ポップアップをコードで実装する方法と、ユーザー体験を損なわないための設計ポイントを解説します。


離脱防止ポップアップが有効なケース

ケース表示するオファー例期待効果
ECサイトのカート離脱「今なら送料無料」「10%OFFクーポン」カート復帰率の向上
SaaSの料金ページ離脱「無料トライアル14日間」「導入事例を見る」トライアル登録率の向上
ブログ記事の離脱「関連資料を無料ダウンロード」「メルマガ登録」リード獲得
LPの離脱「限定価格は本日まで」「無料相談を予約」CVR向上

JavaScriptで実装するexit-intent検出

exit-intentの検出原理は、マウスカーソルがブラウザのビューポート上端を超えた瞬間をmouseleaveイベントで捕捉するものです。

基本的なexit-intent検出

function initExitIntent(callback) {
  const handleMouseLeave = (e) => {
    if (e.clientY <= 0) {
      callback();
      document.removeEventListener('mouseleave', handleMouseLeave);
    }
  };

  setTimeout(() => {
    document.addEventListener('mouseleave', handleMouseLeave);
  }, 5000);
}

参考: mouseleave イベント – MDN Web Docs

setTimeoutで5秒間の遅延を入れることで、ページ読み込み直後の誤検出を防ぎます。

表示頻度の制御

同じユーザーに何度もポップアップを表示するのは逆効果です。localStorageで表示済みフラグを管理し、一定期間は再表示しないようにします。

function shouldShowPopup(popupId, intervalDays) {
  const key = `exit_popup_${popupId}`;
  const lastShown = localStorage.getItem(key);

  if (lastShown) {
    const daysSince = (Date.now() - Number(lastShown)) / (1000 * 60 * 60 * 24);
    if (daysSince < intervalDays) {
      return false;
    }
  }
  return true;
}

function markPopupShown(popupId) {
  localStorage.setItem(`exit_popup_${popupId}`, String(Date.now()));
}

参考: Web Storage API – MDN Web Docs

モーダルUIの実装

HTML5の<dialog>要素を使えば、アクセシビリティに配慮したモーダルを少ないコードで実装できます。

<dialog id="exit-popup">
  <h2>ちょっと待ってください!</h2>
  <p>今なら無料で資料をダウンロードできます。</p>
  <a href="/download" class="cta-button">無料ダウンロード</a>
  <button onclick="this.closest('dialog').close()">閉じる</button>
</dialog>
initExitIntent(() => {
  if (shouldShowPopup('lead-magnet', 7)) {
    document.getElementById('exit-popup').showModal();
    markPopupShown('lead-magnet');
    gtag('event', 'exit_popup_shown', { popup_id: 'lead-magnet' });
  }
});

参考: dialog要素 – MDN Web Docs


モバイルでの離脱防止

モバイルデバイスではマウスカーソルがないため、exit-intentが使えません。代替として以下の手法があります。

手法トリガー条件向いているケース
スクロール率トリガーページの70%以上をスクロールした後、上方向にスクロールした時ブログ記事、LP
滞在時間トリガーページに30秒以上滞在した後料金ページ、比較ページ
非アクティブ検出10秒以上操作がない時フォームページ

UXを損なわないための3つのルール

  1. 閉じるボタンを分かりやすく配置する: 小さなXボタンだけでは不十分。「閉じる」テキストボタンを必ず用意する
  2. 同じユーザーに繰り返し表示しない: 最低7日間は再表示しない。表示頻度が高いとブランドイメージを損なう
  3. ページ読み込み直後に表示しない: 最低5秒はコンテンツを読ませてから表示する。即座のポップアップはGoogleのインタースティシャルガイドラインにも抵触する

よくある質問(FAQ)

Q. 離脱防止ポップアップはSEOに影響しますか?

Googleのインタースティシャルガイドラインでは、ページ読み込み直後の全画面ポップアップはモバイル検索のランキングに影響する可能性があります。exit-intent型(離脱時に表示)であれば問題ありませんが、ページ表示直後のポップアップは避けましょう。

Q. ポップアップツールを使わずに実装できますか?

できます。exit-intent検出はmouseleaveイベント、モーダルUIはHTML5のdialog要素、表示制御はlocalStorageで実装可能です。有料ツール(月額数千円〜)が不要になり、表示速度への影響も最小限に抑えられます。

Q. モバイルでもexit-intentは使えますか?

マウスカーソルがないため、デスクトップと同じexit-intent検出は使えません。モバイルではスクロール方向の変化(下→上)や滞在時間をトリガーとして代替します。

Q. ポップアップの効果を計測するには?

GA4で「ポップアップ表示」「ポップアップ内CTAクリック」「ポップアップ閉じる」の3イベントを送信し、表示→CTAクリックの転換率を計測します。ABテストと組み合わせて、オファー内容や文言の効果を比較することも可能です。

Q. どのページに離脱防止ポップアップを設置すべき?

離脱率が高く、かつコンバージョンに近いページが最優先です。具体的には料金ページ、カートページ、申し込みフォームの直前ページが効果的です。ブログ記事への設置はリード獲得目的であれば有効ですが、情報提供ページには不要です。


離脱防止ポップアップはコードで実装できる

exit-intent検出・モーダルUI・表示頻度制御の3つは、いずれもブラウザ標準のAPIで実装可能です。有料ポップアップツールに月額費用を払う必要はありません。

「自社サイトに最適なポップアップを設計したい」「モバイル対応も含めた実装を依頼したい」という場合は、コードによるCRO実装に対応しているWeb制作チームにご相談ください。


関連記事

▶ まとめ: CROとは?コンバージョン率を改善する8つの手法と始め方

マイクロコピー改善でCVRを上げる方法

EFO(フォーム最適化)とは?離脱率を下げるコード実装ガイド

【P10倍】【30,000円OFFクーポン】【国内… 【P10倍】【30,000円OFFクーポン】【国内… ¥139,800 【新品】Windows11 ノートパソコン office… 【新品】Windows11 ノートパソコン office… ¥39,800 \数量限定★モニター台プレゼント/モニタ… \数量限定★モニター台プレゼント/モニタ… ¥12,800 【楽天1位常連・超700冠獲得】黒/白 モニ… 【楽天1位常連・超700冠獲得】黒/白 モニ… ¥13,999 【SALE】【新製品】ロジクール MX MASTER … 【SALE】【新製品】ロジクール MX MASTER … ¥18,905 【SALE】ロジクール ワイヤレスマウス ト… 【SALE】ロジクール ワイヤレスマウス ト… ¥16,910
Rakuten Web Service Center