当用户打开一个网站时,在Magento主页上打开一个弹出窗口

Open a popup window on Magento home page once when user open a site

本文关键字:一个 主页 窗口 Magento 网站 用户      更新时间:2023-09-26

每次用户访问网站时,我都想在主页中打开一个弹出窗口。现在的问题是每次重新加载主页时都会弹出。我只想显示一次这个弹出窗口。

 <?php $currentUrl = Mage::helper('core/url')->getCurrentUrl();
 if($currentUrl=='http://website.com/')
 {
 ?>
<form action="<?php echo $this->getUrl('subscribe/index/subscriptionsave/'); ?>" id="subscribeForm" method="post">
<div id="boxes">
  <div id="dialog" class="window">
    <div id="popupfoot">  <a class="agree" href="#">close</a> </div>
    <div class="popupcontentbox">
        <div class="box_content">
            <h2>Stay in the loop!!</h2>
            <p>Be the first one to know about new arrivals,
fresh offers &  fashion updates.</p>
         <div class="book-column-left">
        <?php /*?> <label class="f">Email Address<span>*</span></label><?php */?>
         <input type="text" class="input-text required-entry validate-email" placeholder="Email Address *"  name="emailid" id="emailid">
          </div>
           <input type="submit" name="sub" value="Submit" class="btn">
           <div class="offer_text">Get flat 20% Off on your First purchase. Use coupon "INDULGE20".</div>
        </div>
    </div>
  
  </div>
  <div id="mask"></div>
</div>
</form>
 <?php } ?>
<script type="text/javascript">
//<![CDATA[
    var subscribeForm = new VarienForm('subscribeForm', true);
//]]>
    </script>

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.js"></script> 
    <?php */?><script>
    jQuery(document).ready(function() { 
    var id = '#dialog'; 
    //Get the screen height and width
    var maskHeight = jQuery(window).height();
    var maskWidth = jQuery(window).width();
        
    //Set heigth and width to mask to fill up the whole screen
    jQuery('#mask').css({'width':maskWidth,'height':maskHeight});
     
    //transition effect
    jQuery('#mask').fadeIn(500);    
    jQuery('#mask').fadeTo("slow",0.9); 
        
    //Get the window height and width
    var winH = jQuery(window).height();
    var winW = jQuery(window).width();
                  
    //Set the popup window to center
    jQuery(id).css('top',  winH/2-jQuery(id).height()/2);
    jQuery(id).css('left', winW/2-jQuery(id).width()/2);
        
    //transition effect
    jQuery(id).fadeIn(2000);    
        
    //if close button is clicked
    jQuery('.window .agree').click(function (e) {
    //Cancel the link behavior
    e.preventDefault();
    
    jQuery('#mask').hide();
    jQuery('.window').hide();
    });
    
    //if mask is clicked
    jQuery('#mask').click(function () {
    jQuery(this).hide();
    jQuery('.window').hide();
    });
        
         
    jQuery(window).scroll(function() {    
            
    var scroll = jQuery(window).scrollTop();
            if(scroll > 300){
                jQuery(".gotop").addClass("active");
            }else if(scroll < 300){
                jQuery(".gotop").removeClass("active");
            }
    
            
        });
        
        jQuery('.gotop').click(function(){
        jQuery("html, body").animate({ scrollTop: 0 }, 700);
            return false;
         });
    });
    </script>

保存在cookies值中,例如OPENED = 1,然后在php侧打开下一页时检查是否已经存在此类cookie,然后不要添加您的popup代码,也不要在javascript侧进行检查,也不要显示popup

JS实现示例

1)setget cookie函数添加到您的js中-请参阅此处关于setCookiegetCookie的手册-http://www.w3schools.com/js/js_cookies.asp

<script type="text/javascript">
function setCookie(cname, cvalue, exdays) {
    var d = new Date();
    d.setTime(d.getTime() + (exdays*24*60*60*1000));
    var expires = "expires="+d.toUTCString();
    document.cookie = cname + "=" + cvalue + "; " + expires;
} 
function getCookie(cname) {
    var name = cname + "=";
    var ca = document.cookie.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 "";
} 
</script>

2)只需附上显示弹出窗口的if contion代码,正如我从您混乱的代码中了解到的那样,它是jQuery(id).fadeIn(2000);

if( getCookie('popup_opened') == "" ){
     jQuery(id).fadeIn(2000);
     // creates popup_opened cookie and will keep it till browser close
     setCookie('popup_opened', '1', 0)
}

注意:通过此解决方案,您的访问者至少应该在他使用的每个浏览器上看到一次弹出窗口,因为cookie分别存储在每个浏览器中