这是我在这里提到的问题的延伸:
Owl Carousel 2: filtering items,but keep the sort order using Javascript(希望这样可以)
我有一个过滤项目的菜单.我想要从点击和外部页面链接应用过滤器.因此,在第X页上,您单击FilterA,将您引导到Y页面,并将项目过滤到FilterA,就像您刚刚点击过滤器一样.
在理想的世界里,它只会使用一个链接,如www.mysite.com/pageY/#filterA.
您可以在这里查看实时页面:http://bit.ly/1GaL4np
这是过滤功能:
$(document).ready(function () { function showProjectsbyCatEur(cat) { var owl = $(".owl8").data('owlCarousel'); owl.addItem('<div/>',0); var nb = owl.itemsAmount; for (var i = 0; i < (nb - 1); i++) { owl.removeItem(1); } if (cat == 'all8') { $('#projects-copy8 .project8').each(function () { owl.addItem($(this).clone()); }); } else { $('#projects-copy8 .project8.' + cat).each(function () { owl.addItem($(this).clone()); }); } owl.removeItem(0); } $('.owl8 .project8').clone().appendTo($('#projects-copy8')); $('#project-terms8 a').click(function (e) { e.preventDefault(); $('#project-terms8 a').removeClass('active'); cat = $(this).attr('ID'); $(this).addClass('active'); showProjectsbyCatEur(cat); }); });
我的过滤器菜单如下所示:
<div id="filter"> <h1 class="title">Eurorack</h1> <div id="project-terms8"> <ul class="filter"> <li class="filter"><a id="all8" class="active all" onclick="event.preventDefault();" href="#">Show All</a></li> <li class="filter 3x"><a id="3x" onclick="event.preventDefault();" href="#">Clocks,Logic & CV</a></li> <li class="filter 2x"><a id="2x" onclick="event.preventDefault();" href="#">Filters & Resonators</a></li> <li class="filter 1x"><a id="1x" onclick="event.preventDefault();" href="#">Waveform Modifiers</a></li> </ul> </div>
所以迄今为止的答案是有帮助的,但并不完全解决我的问题.如果有任何人有任何建议将是伟大的!似乎使用#没有帮助,因为过滤器使用id,这只是创建锚点到过滤器,所以/?filter = FILTERITEM将是最好的.
或者,新的过滤系统会很好.只要排序顺序保持不变,这可以与URL和按钮一起使用.
解决方法
您可以使用javascript获取一个url参数,并在过滤器中使用该参数.
function getURLParameter(name) {return decodeURIComponent((new RegExp('[?|&]' + name + '=' + '([^&;]+?)(&|#|;|$)').exec(location.search)||[,""])[1].replace(/\+/g,'%20'))||null
}
var filter= getParameterByName('filter'); showProjectsbyCatEur(filter);
然后使链接像“www.mysite.com/pageY/?filter=euro”.