2016-04-04 6 views
0

ich jQuery Isotop bin mit und versuchen, HTML-Text in einem div class zu ändern, mit changeMe, basierend auf if/else:jQuery Isotop if/else Probleme bei der Verwendung indexOf

var $chofval = $(".changeMe").html(filterAttr); 

// search if it contains these strings 
if ($chofval.indexOf("*") >= 0) { 
    $(".changeMe").html("All Apples"); 
} else if ($chofval.indexOf(".green") >= 0) { 
    $(".changeMe").html("Green Apples"); 
} 

Aber es gibt * und .green auf Knopfdruck. Irgendwelche Vermutungen darüber, wo ich falsch liege?

Voll Code:

<script> 
function getHashFilter() { 
    // get filter=filterName 
    var matches = location.hash.match(/filter=([^&]+)/i); 
    var hashFilter = matches && matches[1]; 
    return hashFilter && decodeURIComponent(hashFilter); 
} 

$(function() { 
    var $container = $('.isotope'); 

    // bind filter button click 
    var $filterButtonGroup = $('.filter-button-group'); 
    $filterButtonGroup.on('click', 'button', function() { 
     var filterAttr = $(this).attr('data-filter'); 
     // set filter in hash 
     location.hash = 'filter=' + encodeURIComponent(filterAttr); 

     var $chofval = $(".changeMe").html(filterAttr); 

     // search if it contains these strings 
     if ($chofval.indexOf("*") >= 0) { 
      $(".changeMe").html("All Apples"); 
     } else if ($chofval.indexOf(".green") >= 0) { 
      $(".changeMe").html("Green Apples"); 
     } 
    }); 

    // bind filter on select change 
    $('.filters-select').on('change', function() { 
     // get filter value from option value 
     var filterValue = this.value; 
     // use filterFn if matches value 
     filterValue = filterFns[ filterValue ] || filterValue; 
     $container.isotope({ filter: filterValue }); 
    }); 

    var isIsotopeInit = false; 

    function onHashchange() { 
     var hashFilter = getHashFilter(); 
     if (!hashFilter && isIsotopeInit) { 
      return; 
     } 
     isIsotopeInit = true; 
     // filter isotope 
     $container.isotope({ 
      itemSelector: '.offer-type', 
      layoutMode: 'fitRows', 

      // use filterFns 
      filter: filterFns[ hashFilter ] || hashFilter 
     }); 
     // set selected class on button 
     if (hashFilter) { 
      $filterButtonGroup.find('.is-checked').removeClass('is-checked'); 
      $filterButtonGroup.find('[data-filter="' + hashFilter + '"]').addClass('is-checked'); 
     } 
    } 

    $(window).on('hashchange', onHashchange); 

    // trigger event handler to init Isotope 
    onHashchange(); 
}); 
//@ sourceURL=pen.js 
</script> 

Antwort

0
if(filterAttr == "*") {  
    $(".Me").html("All Apples");  
} 
else if(filterAttr == ".green") { 
    $(".changeMe").html("Green Apples"); 
} 
0

Diese Zeile ändert den Inhalt von „.changeMe“ mit dem Wert von filterAttr und kann nicht den Wert des Inhalts von „.changeMe“ Objekt Retunr.

var $chofval = $(".changeMe").html(filterAttr); 

, wenn Sie möchten, den Inhalt von „.changeMe“ Verwendung zu bewerten bekommen:

var $chofval = $(".changeMe").html(); 

Aber wenn Sie den Wert eines Attributs des Rechtsträger .changeMe als filterAttr definiert zu bekommen versuchen, Verwendung:

var $chofval = $(".changeMe").attr(filterAttr); 

Oder schließlich, wenn filterAttr der reale Wert ist in dem Satz, diesen Wert zu überprüfen, verwenden sie es zu bewerten:

if(filterAttr.indexOf("*") >= 0){ 
    $(".changeMe").html("All Apples"); 
} else if(filterAttr.indexOf(".green") >= 0){ 
    $(".changeMe").html("Green Apples"); 
} 

Siehe JQuery Attr