带有第一个 div 的 jQuery 自定义手风琴在初始加载时打开 - 修改箭头图像的问题
Posted
技术标签:
【中文标题】带有第一个 div 的 jQuery 自定义手风琴在初始加载时打开 - 修改箭头图像的问题【英文标题】:jQuery custom accordion with first div opens on the initial load - issues with modifying arrow images 【发布时间】:2013-04-26 02:43:15 【问题描述】:我在 StackOverlow 上找不到我遇到的问题的答案。我引用了Custom Accordion with arrows 来设置初始手风琴。
我很难根据隐藏的 div 是显示还是隐藏来更改图像图标。
在初始加载时,第一个 (div class="sectionContent") 应打开并带有上箭头图像 -- 我无法将箭头图标更改为上箭头。
部分标题应切换隐藏内容并更改箭头图像。 - 我无法完成这项工作。当我点击隐藏内容可见的部分标题时,箭头图像不会改变。
JSFiddle
var headers = $('.sectionDown a');
var contentAreas = $('.sectionContent').hide();
var firstContentAreas = $('.sectionContent').hide().first().show();
headers.click(function(e)
e.preventDefault();
var panel = $(this).parent('div').next('div');
var isOpen = panel.is(':visible');
$('.sectionDown a').first().addClass('close');
// open or close as necessary
contentAreas.slideUp();
panel[isOpen? 'slideUp': 'slideDown']()
// trigger the correct custom event
.trigger(isOpen? 'hide': 'show');
$('.sectionDown a').removeClass('close');
$(this).removeClass('close').addClass('close');
// stop the link from causing a pagescroll
return false;
);
【问题讨论】:
只需添加或删除包含箭头图像的类作为相对于点击功能和当前代码的背景图像 【参考方案1】:这应该可以解决您的问题。
http://jsfiddle.net/GHLM9/
headers.click(function (e)
e.preventDefault();
var panel = $(this).parent('div').next('div');
var isOpen = panel.is(':visible');
// open or close as necessary
contentAreas.slideUp();
panel[isOpen ? 'slideUp' : 'slideDown']()
// trigger the correct custom event
.trigger(isOpen ? 'hide' : 'show');
$('.sectionDown a').not(this).removeClass('close');
$(this).toggleClass('close');
// stop the link from causing a pagescroll
return false;
);
【讨论】:
以上是关于带有第一个 div 的 jQuery 自定义手风琴在初始加载时打开 - 修改箭头图像的问题的主要内容,如果未能解决你的问题,请参考以下文章
带有 css 或 jquery 的自定义滚动条 firefox