这是我在这里提到的问题的延伸:
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”.