使用Cookies防止用户点击链接两次
Use Cookies to prevent user clicking link twice
我试图防止类。activeadv被添加,如果链接内有它的URL存储在cookie中,如果用户点击链接,这个烹饪被添加,所以基本上我试图停止返回用户点击相同的链接两次。
默认情况下,链接隐藏在div下面,当添加。activeadv类时,div会显示链接。
当前的代码是下面随着项目的代码依赖的例子。我猜我需要将activeAdv addClass包装在IF条件下,其中:
- 获取子链接的href值
- 检查是否存在匹配的cookie
- 仅在条件返回false时添加。activeadv
我认为我有正确的想法,并已经得到了设置cookie点击链接,我正在努力与IF语句虽然,谁可以伸出援助之手?
http://codepen.io/Jambob/pen/wKyoRr <article>
<div id="on-1" class="box">
<h2>1 dec</h2>
</div>
<div class="present">
content
<a href="http://www.google.com">www.google.com</a>
</div>
</article>
// Checks for content within .present, if TRUE adds .activeAdv animation class
$(".present").filter(function(){
return $(this).html().trim().length > 0;
}).parent().addClass('activeAdv');
// When link clicked, store its URL in cookie
$( ".present a" ).click(function() {
$.cookie($(this).attr('href'), true);
});
if ( '(".present").html().trim().length > 0;' ) {
if ( '(".present a").attr("href")' === "http://www.google.com") {
$(this).parent().addClass('activeAdv');
}
}
经过一番思考,我想出了一个不同的IF语句,它可能是沿着正确的行
// Checks if content exists
if ( '(".present").html().trim().length > 0;' ) {
// Checks if HREF of child link matches existing cookie (using a string for testing)
if ( '(".present a").attr("href")' === "http://www.google.com") {
$(this).parent().addClass('activeAdv');
}
}
因此,如果:visited
CSS伪类不够(它匹配访问的链接),您可以使用localStorage
,它更专门于此目的。我创建了一个脚本,可以在Firebug控制台和未访问的链接中运行:
(function(links) {
// Load visited links from local storage
var visited = JSON.parse(localStorage["visited"]||"[]");
// Safety check
if(!visited instanceof Array) {
visited = [];
localStorage["visited"] = [];
}
function setClassToLinks() {
links.each(function(){
// Remember state - asume not visited
var linkVisited = false;
// Check for inner HTML
if(this.innerHTML.trim().length > 0) {
// Check if in list of visited links
if(visited.indexOf(this.href)==-1)
linkVisited = true;
else
console.log("Already visited: "+this.href);
}
else
// Skip empty links
return console.log("No inner HTML.");
// Reset color
this.style.color = !linkVisited?"":"red";
// And remove class
if(linkVisited)
$(this).removeClass("activeAdv");
else
$(this).addClass("activeAdv");
})
}
setClassToLinks();
// When link clicked, store its URL in LocalStorage
links.click(function() {
// Prevent duplicities
if(visited.indexOf(this.href)==-1) {
visited.push(this.href);
localStorage["visited"] = JSON.stringify(visited);
}
});
// [OPTIONAL] Update links realtime - triggers when local storage changes
window.addEventListener('storage', function (event) {
if(event.key=="visited") {
visited = JSON.parse(localStorage["visited"]||"[]");
// Change CSS
setClassToLinks();
}
});
})($("a"));
我的解决方案整洁的方面是,链接自动更新,当你浏览不同的选项卡(提供这个选项卡运行脚本)。
visited
数组可能会迅速增长,这就是为什么我认为cookie是一个坏主意。
相关文章:
- AngularJs正在阻止链接被点击两次
- 为什么在这种情况下要向JQuery添加两个链接
- 页面加载后的第一个锚定链接需要单击两次
- Javascript函数每分钟更改一次链接
- 带有 OnClick 的 jQuery 链接标记 href 需要单击两次才能加载 AJAX
- 同时提取两个链接
- 节点JS,从两个链接同步发出HTTPS请求
- 两个链接的自动更新(根据另一个中的输入)数字输入字段与JavaScript
- 必须点击两次才能触发事件/与iOS的链接
- 使用JavaScript打开链接新窗口(而不是选项卡),无需键入两次URL
- 使用href到两个链接(PHP和一个网页)
- 如何连接到HighCharts中两个链接系列的端点
- 如何使用jQuery区分具有相同内容的两个链接
- 颜色框在图像处有两个链接,但在组中显示一次
- 单击链接两次以使用ui路由器激活状态
- 如何在用户不点击任何链接或按钮的情况下,使用php或javascript强制用户在移动网页上返回两次
- 如何修改给定的代码打开两个链接在一次点击(没有解决方案为我工作)
- 我有两个弹出对话框.我有javascript.目前,当点击两个链接时,只有一个弹出窗口打开
- 重复几次链接添加和删除后,添加新的输入.为什么
- Javascript手风琴菜单,点击一次展开,点击两次链接