首页 > 解决方案 > 如何仅在第一页加载时显示弹出窗口

问题描述

我试图仅在第一个页面加载时显示弹出窗口,但在我当前的脚本中,它仅在刷新页面时才显示弹出窗口。弹出窗口应在您第一次访问该页面时显示,但不会再次显示。

<script type="text/javascript">// <![CDATA[
document.addEventListener('DOMContentLoaded', function() {
function setCookie(cname,cvalue,exdays) {
    var d = new Date();
    d.setTime(d.getTime() + (exdays*24*60*60*1000));
    var expires = "expires=" + d.toGMTString();
    document.cookie = cname+"="+cvalue+"; "+expires;
}

function getCookie(cname) {
    var name = cname + "=";
    var decodedCookie = decodeURIComponent(document.cookie);
    var ca = decodedCookie.split(';');
    for(var i = 0; i < ca.length; i++) {
        var c = ca[i];
        while (c.charAt(0) == ' ') {
            c = c.substring(1);
        }
        if (c.indexOf(name) == 0) {
            return c.substring(name.length, c.length);
        }
    }
    return '';
}

    $(document).ready(function() {
 if(getCookie('popup') !== ''){
        $('.popup-wrapper').css('display','block');      
    } else {
        setCookie('popup','open',1); 
    }

  $('.popup-close').click(function(){
  		setCookie('popup','close',1);
      $('.popup-wrapper').css('display','none');
  });
});
});
// ]]></script>

任何帮助将不胜感激。

标签: javascriptcookies

解决方案


只需在显示弹出窗口后添加 localStorage.setTtem。别忘了做.popup-wrapper display:none

   if(!localStorage.getItem('shownPopUp')){ 
      $('.popup-wrapper').css('display','block');
      localStorage.setItem('shownPopUp', true);
   }

推荐阅读