我想在我的应用中更改已访问链接的颜色。 访问引荐来访问我浏览器中发生的任何访问的问题。如何通过点击我的应用中显示的链接来识别仅发生的访问?
答案 0 :(得分:0)
您可以通过向所有链接添加eventListener或onclick事件来完成此操作。然后为所有链接添加唯一ID并将其添加到cookie。 当您加载应用时,只需读出创建的Cookie并将类名更改为" already_visited"
编辑:
<a id="link1" href="page1.html">link 1</a>
<a id="link2" href="page2.html">link 2</a>
<a id="link3" href="page3.html">link 3</a>
<style type="text/css">
.already_visited{
color: #f00;
}
</style>
<script type="text/javascript">
window.addEventListener("load", function function_name(argument){
var links = eval(getCookie("links_visited"));
for(var i = 0; i < links.length; i++){
document.getElementById(links[i]).classList.add("already_visited");
}
});
/* Add events to all links */
function callback(e) {
var e = window.e || e;
if (e.target.tagName !== 'A'){
return;
}
/* call cookie function */
addToVisited(e.target.id);
}
if (document.addEventListener){
document.addEventListener('click', callback, false);
}
else{
document.attachEvent('onclick', callback);
}
/* cookie function */
function addToVisited(link_id){
var ids = getCookie("links_visited");
if (ids == "") {
setCookie('links_visited', '["'+link_id+'"]', 365);
}
else if(ids.indexOf(link_id) == -1){
var id_array = eval(ids);
id_array.push(link_id);
setCookie("links_visited", '["'+id_array.join('","')+'"]', 365);
}
console.log(getCookie("links_visited"));
}
/* cookie function helpers */
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 + "; path=/";
}
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>
代码应该是不言自明的,但是询问是否有任何不清楚的地方