- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
每次用户访问网站时,我都想在主页上打开一个弹出窗口。现在的问题是每次重新加载主页时都会出现弹出窗口。我只想显示一次此弹出窗口。
<?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) 将 set
和 get
cookie 函数添加到您的 js - 请在此处查看有关 setCookie
和 getCookie
- 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 分别存储在每个浏览器中
关于javascript - 当用户打开一个站点时,在 Magento 主页上打开一个弹出窗口一次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34409609/
在为 Web 应用程序用例图建模时,为用户可以拥有的每个角色创建一个角色是否更好?或拥有一个角色、用户和一个具有特权的矩阵? guest < 用户 < 版主 < 管理员 1: guest 、用户、版主
我无法使用 Elixir 连接到 Postgres: ** (Mix) The database for PhoenixChat.Repo couldn't be created: FATAL 28P
这个问题已经有答案了: Group by field name in Java (7 个回答) 已关闭 7 年前。 我必须编写一个需要 List 的方法并返回 Map> . User包含 Person
感谢您的帮助,首先我将显示代码: $dotaz = "Select * from customers JOIN contracts where customers.user_id ='".$_SESS
我只想向所有用户中的一个用户显示一个按钮。我尝试了 orderByKey() 但没有成功! 用户模型有 id 成员,我尝试使用 orderByChild("id") 但结果相同! 我什至尝试了以下技巧
我们在工作中从 MongoDB 切换到 Postgres,我正在建立一个 BDR 组。 在这一步,我正在考虑安全性并尽可能锁定。因此,我希望设置一个 replication 用户(角色)并让 BDR
export class UserListComponent implements OnInit{ users; constructor(private userService: UserS
我可以使用 Sonata User Bundle 将 FOS 包集成到 sonata Admin 包中。我的登录功能正常。现在我想添加 FOSUserBundle 中的更改密码等功能到 sonata
在 LinkedIn 中创建新应用程序时,我得到 4 个单独的代码: API key 秘钥 OAuth 用户 token OAuth 用户密码 我在 OAuth 流程中使用前两个。 的目的是什么?最后
所以..我几乎解决了所有问题。但现在我要处理另一个问题。我使用了这个连接字符串: SqlConnection con = new SqlConnection(@"Data Source=.\SQLEX
我有一组“用户”和一组“订单”。我想列出每个 user_id 的所有 order_id。 var users = { 0: { user_id: 111, us
我已经为我的Django应用创建了一个用户模型 class User(Model): """ The Authentication model. This contains the u
我被这个问题困住了,找不到解决方案。寻找一些方向。我正在用 laravel 开发一个新的项目,目前正致力于用户认证。我正在使用 Laravels 5.8 身份验证模块。 对密码恢复 View 做了一些
安装后我正在使用ansible配置几台计算机。 为此,我在机器上本地运行 ansible。安装中的“主要”用户通常具有不同的名称。我想将该用户用于诸如 become_user 之类的变量. “主要”用
我正在尝试制作一个运行 syncdb 的批处理文件来创建一个数据库文件,然后使用用户名“admin”和密码“admin”创建一个 super 用户。 到目前为止我的代码: python manage.
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我已在 Azure 数据库服务器上设置异地复制。 服务器上运行的数据库之一具有我通过 SSMS 创建的登录名和用户: https://learn.microsoft.com/en-us/azure/s
我有一个 ionic 2 应用程序,正在使用 native FB Login 来检索名称/图片并将其保存到 NativeStorage。流程是我打开WelcomePage、登录并保存数据。从那里,na
这是我的用户身份验证方法: def user_login(request): if request.method == 'POST': username = request.P
我试图获取来自特定用户的所有推文,但是当我迭代在模板中抛出推文时,我得到“User”对象不可迭代 观看次数 tweets = User.objects.get(username__iexact='us
我是一名优秀的程序员,十分优秀!