![](/img/trans.png)
[英]Open JQuery accordion when link with an id of element within the accordion is clicked
[英]Link to section within Accordion using jQuery
我有2頁。 page1.html
包含一系列鏈接, page2.html
具有手風琴。
我的問題:是否可以直接鏈接到手風琴中的某個部分? 因此,如果我想訪問'Celtic',我該如何創建一個鏈接,以便a)打開正確的“手風琴”選項卡b)錨定到celtic id。
這是我當前的page2.html
代碼: http : //jsfiddle.net/7k9s1pg7/
HTML:
<dl class="accordion">
<dt><a href="" class="container heading">Soccer</a></dt>
<dd id="soccer">
<div id="manutd">
<p>Man Utd</p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
</div>
<div id="celtic">
<p>Celtic</p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
</div>
</dd>
<dt><a href="" class="container heading">Formula 1</a></dt>
<dd id="formula1">
<div id="lewishamilton">
<p>Lewis Hamilton</p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
</div>
<div id="michaelschumacher">
<p>Michael Schumacher</p>
<p> </p>
<p> </p>
<p> </p>
<p> </p>
</div>
</dd>
</dl>
Javascript:
(function($) {
var allPanels = $('.accordion > dd').hide();
var allLinks = $('a.heading');
$('.accordion > dt > a').click(function() {
allPanels.slideUp();
allLinks.removeClass('active');
if ($(this).parent().next().is(":visible")) return false;
$(this).parent().next().slideDown();
$(this).addClass('active');
return false;
});
})(jQuery);
在第1 page1
鏈接中使用定位page2.html#lewishamilton
: page2.html#lewishamilton
並添加到您的JS代碼中
var hash = location.hash;
if (hash) {
var el = $(hash);
el.parent().slideDown();
el.parent().prev().find('a').addClass('active');
}
我最近遇到了同樣的問題。 我通過在.htaccess中設置RewriteRule而不是使用前端代碼來修復它。
我這樣做是因為我的要求是擁有一個用戶友好的URL,以獲得更好的UX。 另一個選擇是使用#
( location.hash
)。
請參閱此問題和答案 。
我的想法是點擊一個看起來用戶友好的URL。 就像是:
http://www.example.com/somepage/something
其中somepage
是帶有somepage
的頁面,而something
是風琴的一部分內的按鈕的ID。
在somepage
,你需要編寫代碼來讀something
從網址上onload
使用window.location.pathname
然后編程點擊something
按鈕。
請注意,這可以解決您的手風琴問題,還可以通過呈現用戶友好的URL來提供良好的用戶體驗。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.