Сортировка товаров магазина на JavaScript

Поділитися
Вставка
  • Опубліковано 22 бер 2019
  • Помоги каналу! donatepay.ru/don/webdev
    Курс JS: js.itgid.info
    Сайт с примером: sort.itgid.info
    Плейлист: goo.gl/63osiv
    Мои курсы: itgid.info
    Телеграм: t.me/jsrules
    Сортировка товара в интернет магазине!

КОМЕНТАРІ • 117

  • @user-ls1xk9ez4w
    @user-ls1xk9ez4w 4 роки тому +1

    Спасибо за уроки.Вы нам очень помогаете 👍👍👍
    Они очень полезные для нас👏👏👏
    Спасибо!!!

  • @user-zl9os2qw1t
    @user-zl9os2qw1t 5 років тому +7

    Доступно и интересно ) спасибо 🙏 твои уроки очень сильно помогают )

    • @itgid
      @itgid  5 років тому +1

      Пожалуйста! Рад!

  • @lera6580
    @lera6580 4 роки тому +2

    Алекс, приветствую! Спасибо огромное за такой урок... Очень хорошая подача, доступно и понятно. Я прям прыгаю от радости =) Лайк, подписка и Ваши курсы тоже заинтересовали... надо будет ознакомиться детально по-свободе. С уважением, Валерия.

  • @user-cv4li6lx2d
    @user-cv4li6lx2d 3 роки тому

    Очень круто, работа проделана великолепно, успехов и спасибо)

  • @1Adanger
    @1Adanger 2 роки тому

    Спасибо за Ваш труд! Мирного неба!

  • @rickgrimes7734
    @rickgrimes7734 5 років тому +1

    просто волшебно!больше видео по JS!!
    Лайк однозначно :)

    • @itgid
      @itgid  5 років тому

      Спасибо!

  • @Ruslan_Emurlaev
    @Ruslan_Emurlaev 3 роки тому

    Спасибо за уроки!!Очень познавательно!!!

  • @laboptyka3706
    @laboptyka3706 3 роки тому

    Отличнейший урок. Спасибо!

  • @romaishutin50
    @romaishutin50 4 роки тому +10

    Бля чувак ты просто лучший, живи вечно ))) Я прост очень долго думал над тем как это реализовать, и тут натыкаюсь на твой видос ❤❤❤

    • @prokop8778
      @prokop8778 10 місяців тому

      Ты написал это 3 года назад, ты сейчас уже хакер должно быть???

  • @sia_mate
    @sia_mate Рік тому

    Спасибо большое! Перерыла интернет, но именно здесь нашла наконец адекватное решение с объяснением, все получилось

  • @greshnicklol5109
    @greshnicklol5109 4 роки тому

    Спасибо за урок, очень познавательно и понятно)

  • @kinomans5141
    @kinomans5141 4 місяці тому

    Господи, спасибо тебе большое!

  • @user-tr1th1dm1g
    @user-tr1th1dm1g 5 років тому

    Очень информативно, спасибо.
    Есть вопрос, можно ли добавить плавности сортировке, возможно анимации, или что-то подобие transition?

  • @chistowick
    @chistowick 3 роки тому

    Спасибо! Отличный урок

  • @user-kz3co1cg6n
    @user-kz3co1cg6n 2 роки тому

    Спасибо огромное, вы очень помогли

  • @igork.3575
    @igork.3575 4 роки тому

    Отличное видео ! Спасибо ! Все четко и доступно !

    • @itgid
      @itgid  4 роки тому

      Рад

  • @user-hq3em8iy9c
    @user-hq3em8iy9c Рік тому

    Спасибо!! Отличный видосик!

  • @ruslanshikhaliev9341
    @ruslanshikhaliev9341 4 роки тому +1

    Хорошая задача.
    Можно поместить кнопки в контейнер, повесить обработчик на него. Каждой кнопке задать data с нужным типом сортировки (или вытаскивать подстроку из id), затем вытаскивать значение data конкретно той кнопки по которой кликнули. и сортировать массив с помощью функции сортировки , в которую передано значение data.
    Чтобы менять элементы местами, можно обойтись без функции(хотя она наверное 100% везде работает) и использовать метод arr[j].after(replaceNode));
    кроме того, если в первом цикле можно указать i < arr.length - 1;чтобы цикл не проходился по последнему элементу(его собственно и сравнивать то не с чем) + если предпоследний больше, он станет последним и его не нужно проверять.
    во втором цикле j = i + 1; таким образом обходов будет на 1 меньше, так как первый раз мы сравниваем arr[0] > arr[0], второй уже arr[0] > arr[1].

  • @icutana
    @icutana Рік тому

    Спасибо! Очень доходчиво)

  • @sergiistryzg9699
    @sergiistryzg9699 5 років тому

    Оговорись в начале) при const содержимое массива или обьекта можно менять) но именно то что внутри него. А вообще ваши видео это в первую очередь обучающие так что как по мне это не важно используете вы let или const

  • @user-ky9bh9zr3c
    @user-ky9bh9zr3c Рік тому

    Спасибо!!! МО-ЛО-ДЕЦ!!!

  • @artsolution-8973
    @artsolution-8973 3 роки тому

    Спасибо, все понравилось.

  • @alexward922
    @alexward922 3 роки тому

    Большое спасибо!

  • @vitoandolinicorleone5394
    @vitoandolinicorleone5394 5 років тому

    Хотелось бы увидеть видео где сортировщик и живой поиск вместе.

  • @viktoriacui
    @viktoriacui 4 роки тому

    Оооочень крутой урок!!!!

  • @aleksandrstaetskiy5687
    @aleksandrstaetskiy5687 5 років тому +4

    Отличное видео

    • @itgid
      @itgid  5 років тому

      Спасибо!

  • @Alim0408
    @Alim0408 9 місяців тому

    Спасибо большое

  • @YOUarStudio
    @YOUarStudio 3 роки тому

    Спасибо большое .

  • @user-cy4js3xv7w
    @user-cy4js3xv7w 5 років тому +2

    Супер! поиск будет с сортировкой? можно еще ссылку на исходники на гитхабе?

    • @itgid
      @itgid  5 років тому

      Это чистый JS. Скопировать код можно по ссылке sort.itgid.info

  • @itoorgenev
    @itoorgenev 5 років тому

    Сильная штука.

  • @ivanrazin3146
    @ivanrazin3146 5 років тому

    здорово,просто и доступно, давайте попишем ботов

  • @user-wv5vk5wx9f
    @user-wv5vk5wx9f 4 роки тому +1

    Добрый день, Андрей. Спасибо за ваш труд!!! Больщая Просьба объяснить вот след кусочек кода.. if(a[ i ] > a[j ] { let temp = a[ i]; a [] =a[j ]; a[ j ] = temp;}

  • @LuckyStilet1
    @LuckyStilet1 5 років тому

    у вас версия gulp наверное обновилась до последней, там нужно код немного переписать в gulpfule

  • @user-yu9to7jr8p
    @user-yu9to7jr8p 2 роки тому

    Доброго дня!
    Раніше у своїх відеоуроках Ви показували як створити корзину з використанням goods.json та скрипта eshop.js.
    Фактично в .html лише голий блок, в який скрипт завантажує дані. Чи можливо їх після завершення завантаження відсортувати, при цьому не змінюючи структури html, eshop.js та goods.json, але підключивши Ваш приклад з цього відео як окремий скрипт? Якщо ні, тоді що саме треба змінити? Адже, по-факту, у самому блоці штмл немає даних. Дякую.

  • @PlayArtChelny
    @PlayArtChelny 3 роки тому

    Спасибо !

  • @morkich
    @morkich 5 років тому +1

    Алекс, ваши видео про JS лучшие на ютуб. Вместе с чтением документации, они производят для меня паразительный эффект. Спасибо Вам большое.
    В интернете нет информации как сделать нормальный свайп слайда на мобильном устройстве. Очень прошу сделать на эту тему видео.
    Заранее спасибо.

  • @kawaikaino5277
    @kawaikaino5277 5 років тому +4

    Я хочу получить его детей, звучит как-то жестоко очень... ахаха на этом моменте выпал 😅😂

    • @itgid
      @itgid  5 років тому

      Иногда ляпнешь, и думаешь, а поскольку я не монтирую видео, получается прикольно!

  • @pavelarseyev452
    @pavelarseyev452 5 років тому +3

    Хочу унать, как в es6 можно поменять значение элементов в массиве без промежуточной переменной!
    И еще...если в первом цикле i = 0, а во втором цикле j = i, то мы начинаем сравнивать не первый элемент в массиве со вторым, а первый с первым, потому что на первой итерации i-цикла i = 0, и на первой же итерации j-цикла j = i = 0. Чтобы было так, как озвучено в видео нужно во втором цикле написать j = i+1.

    • @dukalis55
      @dukalis55 5 років тому

      es6 деструктуризация, вроде бы так [ a[i], a[j] ] = [ a[j], a[i] ]; , думаю меня поправят если, что не так

    • @pavelarseyev452
      @pavelarseyev452 5 років тому

      @@dukalis55, спасибо, почитаю про деструктуризацию

    • @ruslanshikhaliev9341
      @ruslanshikhaliev9341 4 роки тому

      @@dukalis55 ты прав

  • @pandaskeptic2937
    @pandaskeptic2937 5 років тому +2

    Супер! Спасибо за видео!) 👍👍👍
    Минус только разрешение 360.

    • @itgid
      @itgid  5 років тому +1

      Можно обновить страницу и уже fullHd

    • @pandaskeptic2937
      @pandaskeptic2937 5 років тому

      @@itgid Это другое дело. Топ 👍👍👍🔥.

  • @user-no3rr2wk2g
    @user-no3rr2wk2g 5 років тому

    Полезно. Сортировка - не самая очевидная вещь

  • @qwerty-mi7ss
    @qwerty-mi7ss 4 роки тому

    как это сделать через select таким образом, что бы оно и в chrome работало?

  • @dukalis55
    @dukalis55 5 років тому

    Спасибо, очень интересно. Подскажите, а как можно грамотно реализовать сортировку по рейтингу, но при каждом клике на кнопку id="sort-rating" она менялась бы, то от большего к меньшему, то от меньшего к большему.

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому

      Я бы кнопке присвоил атрибут, в каком направлении сортировать. При нажатии на кнопку проверял бы атрибут на true или false. А от значения атрибута вызывал бы либо одну функцию, либо другую и переключал атрибут. Там же можно и текст на кнопке менять, либо стрелочку вверх-вниз.

  • @kreativ4ik44
    @kreativ4ik44 3 роки тому

    Так какой способ сортировки методом пузырька без промежуточной переменной в ES 6 ?

  • @luckyrobot3688
    @luckyrobot3688 3 роки тому

    Дата атрибут можно же получить с помощью dataset например в данном случае получаем dataset.sort

  • @euStiuMaiBine
    @euStiuMaiBine 4 роки тому

    Bravo!!

  • @therelaxingsound6903
    @therelaxingsound6903 9 місяців тому

    Как вы указали что именно мониторы с картинкой должны быть первыми в рейтинге?

  • @heyter1579
    @heyter1579 4 роки тому

    23:28 когда код заработал без ошибок, телефон на заднем плане пикнул

  • @smirnov7632
    @smirnov7632 5 років тому +2

    Спасибо Вам, очень познавательное видео, а как сделать сортировку по бренду , по диагонали монитора?

    • @itgid
      @itgid  5 років тому

      логика такая же. Т.е. вы должны присвоить определенный data по которому будете осуществлять сортировку. Но заметьте - делать это через базу данных в разы проще.

  • @andreystepanov982
    @andreystepanov982 5 років тому

    Скажите пожалуйста актуальна ли эта книга на сегодняшний день - Дэвид Флэнаган "JavaScript. Подробное руководство"?

    • @user-vw7re3uz1b
      @user-vw7re3uz1b 4 роки тому

      Актуальна. Это самая информативная книга по теоретическим основам JS. Если совмещать её с learn.javascript.ru и прорешивать задачки в конце каждой главы, всё будет хорошо.
      Но я бы не решился читать Подробное руководство. Возьмите "Карманный Справочник" Флэнагана и штудируйте его с learn js, если будет не хватать инфы всегда можно погуглить

  • @dveleoperbek1349
    @dveleoperbek1349 2 роки тому

    a без нажатия кнопки просто по сортировке можно? как делать?

  • @user-vw3wy3tq1s
    @user-vw3wy3tq1s Рік тому

    Повторил код полностью у себя на проекте, не работает. Выдает ошибку: 'Uncaught TypeError: Cannot read properties of undefined (reading 'parentNode')'

  • @digitalturkistan1857
    @digitalturkistan1857 5 років тому

    Дважды смотрел дважды спасибо.

  • @daniil7243
    @daniil7243 3 роки тому

    а "J" в "j=i" равен одному с самого начала,тогда как i=0 ?

  • @user-qx7bc9dz5p
    @user-qx7bc9dz5p 3 роки тому

    Ребят а где пример можно скачать?

  • @olegonkos
    @olegonkos 3 роки тому

    это получается, что для каждого товара в HTML нужно добавлять атрибут, который равен цене. А если цена изменится? Ну например, если из 1С выгрузили товар с новой ценой, а в HTML атрибут записан со старой цифрой.

    • @PlayArtChelny
      @PlayArtChelny 3 роки тому

      Это через php)) Все вопросы к нему !)

  • @user-vn5bv1hw2t
    @user-vn5bv1hw2t 4 роки тому +1

    Такой вопрос, прошу помочь для знающего js думаю он очень прост. Если открыть сайт пример в IE11 всё хорошо работает, а версии IE10 и ниже, выдаёт такую ошибку. Предполагается наличие ';' sorted_menu.js (12,9)

    • @user-vn5bv1hw2t
      @user-vn5bv1hw2t 4 роки тому

      UPD: поменял везде let на var и на IE10 всё работает =)

    • @user-ik1uv1kh3l
      @user-ik1uv1kh3l 4 роки тому

      @@user-vn5bv1hw2t используйте babel, что бы переводить 6й стандарт в пятый. Тогда можно и стрелочные функции не бояться использовать, а так же let , const и т.д. )

  • @user-vn5bv1hw2t
    @user-vn5bv1hw2t 4 роки тому +1

    Помогите пожалуйста! Всё работает и сортируется, на той странице где есть кнопки. А на других странциах, в консоли пишется (Uncaught TypeError: Cannot set property 'onclick' of null).

    • @user-vn5bv1hw2t
      @user-vn5bv1hw2t 4 роки тому +1

      UPD: Проблему решил путем условия.

  • @jahongirzokirov3453
    @jahongirzokirov3453 4 роки тому

    Захотелось немного повыпендриваться и сделать с помощью метода sort (), но не получается, подскажите как нибудь, пожалуйста, Алекс.

    • @jorgenUA
      @jorgenUA 4 роки тому

      arr.sort((prev, next) => {
      return prev - next;
      });

  • @user-kh7fv5rn1g
    @user-kh7fv5rn1g 5 років тому

    Спасибо, все предельно понятно. жаль разрешение слабое - 360, посмотрю подробнее в примере, не проблема. а так - супер!

    • @itgid
      @itgid  5 років тому +1

      Обновите страниу. И вуаля fullHD!

    • @user-kh7fv5rn1g
      @user-kh7fv5rn1g 5 років тому +1

      Спасибо! сработало! . и еще - можете сотворить видео по квизу со сбором данных , еще там процент скидки как то встраивается. никак не пойму - это типа слайдера - без перезагрузки страницы,? как это вообще работает? пример: paradigma.website/quiz/kovrolin/

    • @itgid
      @itgid  5 років тому

      @@user-kh7fv5rn1g Посмотрим. Собрать данные не проблема, а что с ними делать дальше? Нужен бекенд.

  • @yeah1727
    @yeah1727 5 років тому +1

    Спасибо за уроки!У меня есть 2 вопроса:1.Чтобы сделать Магазин обязателен ли cms,php или можно просто всю логику прописывать на js?.2.Каждая страница сайта это новый html файл или нет?(Новичок в этом деле,не судите строго за глупые вопросы).

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому +6

      Нужен php и проще с cms. В принципе, В ТЕОРИИ, можно сделать магазин на фронтэнде (без php, хотя, так не корректно, т.к. на сервере может быть и не php). Но для этого ты должен пользователю отправлять сразу ВЕСЬ МАГАЗИН (все наименования товаров, описания, изображения, отзывы, страницы корзины, контактов и т.п.). А JS уже смотреть, что показывать, а что нет. Честно говоря, хотел бы я посмотреть на такого урода )). И, в принципе, невозможно (хотя, нет ничего невозможного) будет организовать личный кабинет, регистрацию пользователей и сохранение их истории.
      Нормальный магазин работает так: все данные о товарах, о категориях, отзывы, контактные данные, данные о зарегистрированных пользователях и прочее хранятся в базе данных. Для этого на сервере работает СУБД. По запросу пользователя php обращается к СУБД, получает данные, с помощью них формирует HTML-страницу, которую в данный момент должен увидеть пользователь, указывает в HTML какие css и js она должна использовать, и отправляет HTML-страницу пользователю. Браузер разбирает HTML, подгружает нужные данные, и отображает страницу пользователю. Когда пользователь совершает действия, по которым нужны новые данные (перешел на страницу товара, нужно описание, отзывы, цена, данные о скидках, и большое фото и прочее) снова делается запрос на сервер, включается php, обращается к СУБД, формирует новую HTML-страницу и отправляет пользователю (может и не страницу, а просто данные, но это уже другая история). Таким же образом организуется доступ к аккаунтам (данные о логине и пароле хранятся в базе данных) и формируются страницы с учётом прав доступа, истории посещений и т.п. (всё хранится в базе данных).

    • @yeah1727
      @yeah1727 4 роки тому +1

      Спасибо большое,глаза открыли)@@simplewebdev1098

    • @bakurikokhodze8250
      @bakurikokhodze8250 4 роки тому +1

      @@simplewebdev1098 хороший ответ super

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому

      ​ Bakuri Kokhodze я бы не согласился и поспорил с товарищем, который написал этот ответ. Дело в том, что за время, которое прошло с момента написания того комента, я узнал, что есть такая вещь, как React (Angular, Vue). Это, как-раз, билиотеки /фреймворки, которые позволяют сделать магазин (и не только) на фронтэнде на JavaScript-е. А необходимые данные подтягивать при помощи REST-запросов на сервер. И можно авторизацию сделать, разделение прав и всё такое. Конечно, на чистом JS, без использования подобных библиотек/фреймворков, провернуть такое довольно сложно.

  • @ramforinh
    @ramforinh 5 років тому +2

    Это не сортировка пузырьком, а selection sort. В пузырьковой сортировке сравниваются всё время соседние элементы и меняются местами если надо. В результате элементы как бы всплывают после каждого цикла. Потому и пузырёк называется.

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому

      Ты не прав автор видео прав.

  • @Federation1323
    @Federation1323 4 роки тому

    Ёмас, анумн патс =)

  • @user-et1xj4kd6o
    @user-et1xj4kd6o Рік тому

    у меня по убыванию только со второго клика работает, из-за чего это может быть?

    • @NoxiousWM
      @NoxiousWM Рік тому

      Вы записали let j = 0 а надо j = i, а то что со второго клика это не понятно что.

  • @firewatermoonsun
    @firewatermoonsun 4 роки тому

    Немного запутался..в "insertAfter(replacedNode, items.children[i]);" ..replacedNode и items.children[i] - это же одно и то же значение?)

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому

      Нет. Мы же в replacedNode получаем items.children[j]. Функция replaceChild убирает первый аргумент, ставит вместо него второй, и возвращает первый.

    • @firewatermoonsun
      @firewatermoonsun 4 роки тому

      @@simplewebdev1098 Посмотрите здесь developer.mozilla.org/ru/docs/Web/API/Node.replaceChild Они пишут, что второй аргумент идет в replacedNode, т.е. в нашем случае nav.children[i] ("replacedNode замененный элемент. Тоже самое что и oldChild.")

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому

      @@firewatermoonsun так и есть. Я всегда думал, что первым аргументом передаётся старый элемент. Странно, нужно внимательно проанализировать код.

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому

      @@firewatermoonsun теперь понятно. У нас же nav.children[i] уже новый, после replaceChild.

    • @firewatermoonsun
      @firewatermoonsun 4 роки тому

      @@simplewebdev1098 22:40 Значит вы имеете в виду что в [insertAfter(replacedNode, nav.children[i])], nav.children[i] уже новый, а в replacedNode записан старый nav.children[i]? Я просто не вижу, как он может взять новый nav.children[i]...программа же по порядку идет, и не понял на каком этапе сработал [i++] ?

  • @user-ve8om5zg3s
    @user-ve8om5zg3s 3 роки тому +2

    И после появляются сайты, которые жрут ресурсы.

    • @user-ve8om5zg3s
      @user-ve8om5zg3s 3 роки тому

      @World Peace Справедливо. Курсы яндекса ответят на ваши вопросы.

  • @ericenderson3415
    @ericenderson3415 4 роки тому

    я хочу получить его детей))))

  • @pandaskeptic2937
    @pandaskeptic2937 5 років тому

    var arr = [2,5,6,9,1,3,4,8,7];
    var str = arr.sort(sort);
    var newArr = [];
    function sort(a,b){
    if (a > b) {
    return 1;
    }
    if (a < b) {
    return -1;
    }
    }
    for (var i =0;i

  • @capy7773
    @capy7773 5 років тому +1

    А не проще использовать sort?

    • @olegonkos
      @olegonkos 3 роки тому

      покажи код

  • @glebboyarshinov9312
    @glebboyarshinov9312 5 років тому

    Хммммм перешёл на твой сайт , скопировал твой код. Не работает(( Даже ошибок не пишет. Хм... что-то ты нам не договариваешь.

    • @-web2378
      @-web2378 5 років тому

      ибо надо немног с js дружить)

  • @jorgenUA
    @jorgenUA 4 роки тому

    метод sort быстрее в десятки раз. проверил на сгенерированном массиве из 10тыс элементов. Ну ,просто поделился

  • @paulfox8646
    @paulfox8646 5 років тому

    По-моему, у вас не "чистый пузырек". Получается, что цикл проходится по уже отсортированным элементам массива.

    • @simplewebdev1098
      @simplewebdev1098 4 роки тому +1

      Единственное там, похоже j = i + 1, но это просто опечатка. А так, вроде, всё норм.

    • @ruslanshikhaliev9341
      @ruslanshikhaliev9341 4 роки тому

      @@simplewebdev1098 в первом цикле arr.length - 1 нужно

  • @nakturnal2008
    @nakturnal2008 5 років тому +1

    а зачем менять местами блоки если можно отсортировать и перерисовать все одним разом ?
    function sort(){
    let blocks = $('.item');
    let sorted = false;
    $('#sortButton').click(function () {
    if(sorted) {
    blocks.sort((a, b) => b.dataset.price - a.dataset.price);
    sorted = false;
    }else{
    blocks.sort((a, b) => a.dataset.price - b.dataset.price);
    sorted = true;
    }
    $('#items').html(blocks);
    })
    }

  • @digitalturkistan1857
    @digitalturkistan1857 5 років тому +1

    Спасибо большое

    • @itgid
      @itgid  5 років тому

      Вам отдельное спасибо!