3
嗨,我主要是一个设计师,但采取它在自己了解发生的事情引擎盖下帮我设计出更好的网站。首先李不显示活动内容
这是第一个网站,我已经设计并从头开始建立,所有被顺利,直到我打这个问题有UL里的活动状态。
下面是测试版的链接:http://www.philmckeith.com/stonebridge/2012/4-bedroom-house-the-york-bingley.html。
与下拉的框是嵌套内容目前。
HTML:
<div id="dd" class="wrapper-dropdown-2" tabindex="1">
<span>House Types</span>
<ul class="dropdown">
<li id="dd1"><a href="javascript:void(0);">Chester</a></li>
<li id="dd2"><a href="javascript:void(0);">Durham</a></li>
<li id="dd3"><a href="javascript:void(0);">York</a></li>
<li id="dd4"><a href="javascript:void(0);">Westminister</a></li>
<li id="dd5"><a href="javascript:void(0);">Ripon</a></li>
</ul>
</div>
<div id="content1" class="content"><img src="images/new-homes-bingley-chester-plan.png"></div>
<div id="content2" class="content"><img src="images/new-homes-bingley-durham-plan.png"></div>
<div id="content3" class="content"><img src="images/new-homes-bingley-york-plan.png"></div>
<div id="content4" class="content"><img src="images/new-homes-bingley-westminister-plan.png"</div>
<div id="content5" class="content"><img src="images/new-homes-bingley-ripon-plan.png"></div>
的Javascript选择:
$(document).ready(function() {
//Active first link
//var activeId = $(".active").attr("id").replace("dd",""); $("#content" + activeId).show();
$("#dd a").click(function() {
//reset
$(".content").hide(); //Hide all content
$("ul.dropdown li:first").addClass("active").show(); //Activate first tab
$(".content:first").show(); //Show first tab content
$("#dd .active").removeClass("active");
//act
$(this).addClass("active")
var id = $(this).closest("li").attr("id").replace("dd","");
$("#content" + id).show();
});
});
的Javascript切换:
function DropDown(el) {
this.dd = el;
this.initEvents();
}
DropDown.prototype = {
initEvents : function() {
var obj = this;
obj.dd.on('click', function(event){
$(this).toggleClass('active');
event.stopPropagation();
});
}
}
$(function() {
var dd = new DropDown($('#dd'));
$(document).click(function() {
// all dropdowns
$('.wrapper-dropdown-2').removeClass('active');
});
});
的风格UL下拉菜单中选择隐藏的内容确定,但不显示第一Li含量在页面加载。我在stackoverflow上找到的壁橱文章就是这个解决方案。 using jquery to change visibility of divs with nested content, onclick
我曾尝试以下,但没有运气作为尚未:
$('li').eq(0).addClass("active");
我猜我切换脚本和选择剧本是相互矛盾或重复莫名其妙,但不确定如何解决这个问题。任何帮助/建议/文章非常感谢。
感谢这个St3inn大加赞赏供职的选择,但创造的切换脚本的问题这让下拉坚持过。内容的顶部直到再次点击。我已经更新了测试版链接以显示我的意思:[link](http://www.philmckeith.com/stonebridge/2012/4-bedroom-house-the- york-bingley.html)。将尝试并找到一种方法,但如果有人有任何想法,我会欢迎他们。 – PMckeith
通过从您的答案的第6行删除一个#dd纠正我刚刚在上面发布的错误。除非有双倍dd没有双关语意图的原因:) – PMckeith
认为这是必要的(除了.active之外引用#dd本身),但显然它不是:)我听说过的唯一情况在哪里可能有太多的dd;) – st3inn