2

I am using list.js to sort list item but i want to sort the item on changing the select > option

HTML

<div id="hotels">
    <input class="search" placeholder="Search" />
    <button class="sort" data-sort="name">
      Sort by name
    </button>

    <select class="sort" data-sort="">
      <option value="" selected>Sort by</option>
      <option value="hotelName">Hotel Name</option>
      <option value="price">Price</option>
      <option value="star">Star</option>
    </select>

    <ul class="list">
      <li>
        <h3 class="hotelName">The Umrao</h3>
        <p class="price">5002</p>
        <p class="star">3</p>
      </li>
      <li>
        <h3 class="hotelName">Welcomhotel Dwarka, New Delhi</h3>
        <p class="price">8367</p>
        <p class="star">5</p>
      </li>
      <li>
        <h3 class="hotelName">Lemon Tree Premier, Delhi Airport</h3>
        <p class="price">3978</p>
        <p class="star">4</p>
      </li>
      <li>
        <h3 class="hotelName">Red Fox Hotel, Delhi Airport</h3>
        <p class="price">9676</p>
        <p class="star">2</p>
      </li>
    </ul>
  </div>
  <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
  <script src="http://listjs.com/no-cdn/list.js"></script>

I have done some code but it has bug when i select first time it works but if i go to change again on clicking select it sort item with the previous value and after when dropdown open then i select then it sort with current value.

Here is my code

var options = {
  valueNames: [ 'hotelName', 'price', 'star' ]
};

var hotelList = new List('hotels', options);

$('.sort').change(function(){
  var selection = $(this).val();
  console.log(selection);
  $(this).attr('data-sort', selection);
});

1 Answer 1

2

You should use the hotelList.sort function for that:

var options = {
  valueNames: [ 'hotelName', 'price', 'star' ]
};

var hotelList = new List('hotels', options);

$('select.sort').change(function(){
  var selection = $(this).val();
  hotelList.sort(selection);
});

$('button.sort').click(function() {
  hotelList.sort($(this).data('sort'));  
});
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
<script src="http://listjs.com/no-cdn/list.js"></script>
<div id="hotels">
  <input class="search" placeholder="Search" />
  <button class="sort" data-sort="hotelName">
    Sort by name
  </button>

  <select class="sort">
    <option value="" selected>Sort by</option>
    <option value="hotelName">Hotel Name</option>
    <option value="price">Price</option>
    <option value="star">Star</option>
  </select>

  <ul class="list">
    <li>
      <h3 class="hotelName">The Umrao</h3>
      <p class="price">5002</p>
      <p class="star">3</p>
    </li>
    <li>
      <h3 class="hotelName">Welcomhotel Dwarka, New Delhi</h3>
      <p class="price">8367</p>
      <p class="star">5</p>
    </li>
    <li>
      <h3 class="hotelName">Lemon Tree Premier, Delhi Airport</h3>
      <p class="price">3978</p>
      <p class="star">4</p>
    </li>
    <li>
      <h3 class="hotelName">Red Fox Hotel, Delhi Airport</h3>
      <p class="price">9676</p>
      <p class="star">2</p>
    </li>
  </ul>
</div>

Sign up to request clarification or add additional context in comments.

2 Comments

sort() is function of jquery of list.ja
one more thing is ther any way to sort low to high or A-to-Z for example in select there is two option of price <option value="price-low-high"> Price Low to High</option><option value="price-high-low"> Price High to Low</option>

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.