2017-09-06 87 views
0

我想根据系统日将class="filter"更改为class="active filter"。我知道如何获得系统日,但无法改变课程。任何人都可以帮助我吗?HTML元素的JavaScript更改类

<li id="0"><a href="javascript:;" data-filter="all" class="active filter">All</a></li> 
<li id="1"><a href="javascript:;" data-filter=".monday" class="filter"> Monday</a></li> 
<li id="2"><a href="javascript:;" data-filter=".tuseday" class="fiter">Tuesday </a></li> 
<li id="3"><a href="javascript:;" data-filter=".wednesday" class="filter"> Wednesday</a></li> 
<li id="4"><a href="javascript:;" data-filter=".thursday" class="filter"> Thursday</a></li> 
+0

Bad id的'Element.className'是JavaScript访问。 – PHPglue

回答

1

使用JavaScript更改类:

element.classList.add  // adds a class 
element.classList.remove // removes a class 

你会遍历所有的元素,并添加活动类到符合你系统日的那个。 (您可以使用getAttribute('data-filter')与您的系统日子比较。)

var sysDay = 'monday'; 
 

 
var activeDay = function(sysDay) { 
 
    var days = document.getElementsByClassName('day'); 
 
    for (var i=0; i<days.length; i++) { 
 
    // remove active class 
 
    days[i].classList.remove('active'); 
 
    // add active class only if matches system day 
 
    if ((days[i].getAttribute("data-filter")) == sysDay) 
 
    { 
 
     days[i].classList.add('active'); 
 
    } 
 
    } 
 
} 
 

 
activeDay(sysDay);
.active { 
 
    color: red; 
 
}
<li id="0"><a href="javascript:;" data-filter="all" class="active filter day">All</a></li> 
 
<li id="1"><a href="javascript:;" data-filter="monday" class="filter day"> Monday</a></li> 
 
<li id="2"><a href="javascript:;" data-filter="tuseday" class="fiter day">Tuesday </a></li> 
 
<li id="3"><a href="javascript:;" data-filter="wednesday" class="filter day"> Wednesday</a></li> 
 
<li id="4"><a href="javascript:;" data-filter="thursday" class="filter day"> Thursday</a></li>

+0

我不知道我做错了什么。非解决方案正在为我工​​作。我想要做的是根据此页面上的系统日选择一天。 www.nightclubslondon.com/london_nightclubs.html ..请帮助我。 –

+0

从系统返回的数据格式是什么?你需要确保'data-filter'属性的值完全匹配它。我发现'data-filter'的值是以一个句点开始的。你一定要删除它,因为它们不是有效的JavaScript变量。 –

+0

非常感谢您的帮助。它的工作现在。 –

0
var listItem = document.getElementById('0') 
listItem.classList.toggle('active'); 

你或许应该改变你的IDS虽然

+0

我不知道我在做什么错。没有解决方案为我工作。我想要做的是根据此页面上的系统日选择一天。 www.nightclubslondon.com/london_nightclubs.html –

0
<ul class="text-center"> 
<li id="1"><a href="#" data-filter=".monday" class="filter"> Monday</a></li> 
<li id="2"><a href="#" data-filter=".tuseday" class="fiter">Tuesday </a></li> 
<li id="3"><a href="#" data-filter=".wednesday" class="filter"> Wednesday</a></li> 
<li id="4"><a href="#" data-filter=".thursday" class="filter"> Thursday</a></li> 
<li id="5"><a href="#" data-filter=".friday" class="filter">Friday</a></li> 
<li id="6"><a href="#" data-filter=".saturday" class="filter"> Saturday</a></li> 
<li id="0"><a href="#" data-filter=".sunday" class="filter"> Sunday</a></li> 
</ul> 

<script> 
    ActiveDay(); 
    function ActiveDay() 
    { 
     var day = new Date().getDay(); 

     for (var i = 0; i < 7; i++) 
     { 
      $("#" + i + ">a").attr("class", "filter"); 
     } 

     $("#" + day + ">a").attr("class","active filter"); 
    } 

    </script>