javascript - 如何仅在第一页加载时显示弹出窗口
问题描述
我试图仅在第一个页面加载时显示弹出窗口,但在我当前的脚本中,它仅在刷新页面时才显示弹出窗口。弹出窗口应在您第一次访问该页面时显示,但不会再次显示。
<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>
任何帮助将不胜感激。
解决方案
只需在显示弹出窗口后添加 localStorage.setTtem。别忘了做.popup-wrapper
display:none
if(!localStorage.getItem('shownPopUp')){
$('.popup-wrapper').css('display','block');
localStorage.setItem('shownPopUp', true);
}
推荐阅读
- aws-lambda - 如何使用放大通知向特定设备发送通知
- json - Flutter - 接受 json id 值
- delphi - 接收 HEX 数字并转换为 INT 或 STRING
- php - 在 elementor 中单击按钮上调用函数
- flutter - 如何在颤动中在键盘和焦点文本字段之间添加空格?
- python-3.x - AWS Lambda python:无法导入模块“lambda_function”:没有名为“regex._regex”的模块
- excel - 当我在 excel 上打开 csv 或 excel 文件时,日期格式为 Oct 20, 2020 12:58 PM,但不将它们识别为日期。我能做些什么?
- c# - 数字格式字符串 #,#0.00 与 #,0.00
- python - 我无法使用散点图的 Python 进行线性回归以获得使用 Origin 获得的预期值
- odata - SAPUI5:ODatav4 将静态数据添加到从 API 下载的数据中