Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.68/47: Рейтинг темы: голосов - 47, средняя оценка - 4.68
1 / 1 / 1
Регистрация: 11.02.2018
Сообщений: 117

Корзина на сайте

29.05.2020, 21:11. Показов 9864. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет всем! Есть кнопка добавления товара в корзину. Нужно создать массив с товарами. Хранение цены и количество нужно отдельно. Также должна быть функция добавление товара, которая принимает id товара. После изменения массива, вызывается функция изменение html-кода в корзине исходя из текущего состояния массива товаров.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.05.2020, 21:11
Ответы с готовыми решениями:

Корзина на сайте
Здравствуйте, прошу помощи! На сайте есть корзина заказов и разделы в которые можно добавлять через админ панель, при добавлении...

Не так работает прсотая ajax корзина на сайте
Привет, ребят. Помогите пожалуйста разобраться с кодом. Есть у меня на сайте ajax корзинка. Ничего сложно просто фоновая картинка и...

Корзина
Доброго времени форумчане. Может Вы где то встречались с таким: Корзина, на раб. столе, вдруг поменяла название на: RecycleBin. Из-за...

4
Эксперт JS
 Аватар для DrType
6553 / 3624 / 1075
Регистрация: 07.09.2019
Сообщений: 5,877
Записей в блоге: 1
30.05.2020, 17:21
Лучший ответ Сообщение было отмечено Андрэ1 как решение

Решение

Здравствуйте.
Не совсем понимаю, зачем хранить цены и количества "отдельно". Идея такая: есть массив объектов (товаров), у каждого есть ключи: id, цена, количество. Есть пустой массив — корзина. Функция принимает id, помещает товар во второй массив, декрементирует количество. В корзине могут оказаться одинаковые товары; этого можно не допустить, если не просто добавлять в корзину, а предварительно проверять по id. Пусть у товара будет ещё одно свойство: количество в корзине.

Добавлено через 22 минуты
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
class Product {
  constructor(id, price, quant) {
    this.id = id;
    this.price = price;
    this.quant = quant;
  }
}
Product.prototype.bought = 0;
const goods = [
  new Product("book", 1500, 15),
  new Product("computer", 25000, 5),
  new Product("phone", 7500, 50)
];
const basket = [];
function add(id) {
  const sort = goods[goods.findIndex((product) => product.id == id)];
  if (sort.quant) {
    sort.quant--;
    if (!basket.some((product) => product.id == id)) {
      basket.push(sort);
    }
    sort.bought++;
  }
}
3
Эксперт JS
6497 / 3908 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
31.05.2020, 07:11
Здравствуйте.
Вот вполне исправно работающая корзина:
Как вывести данные в один и тот же текстовый инпут, если необходимо использовать функции onClick с разных кнопок?
JavaScript
1
2
        // Массив товарных строк для отправки на сервер (id товара + цена + количество)
        var cart = [];
Пример добавления товарной строки в корзину:
JavaScript
1
               cart.push({ id: id, price: price, count: count });
Там осталось только доделать красивое отображение товаров в самой корзине.

Тут важно помнить, что товарная строка документа не является описанием товара в номенклаторе товаров. Это разные объекты.
То есть класс "Towar" и класс "StrokaKorziny" это разные классы ))
1
1 / 1 / 1
Регистрация: 11.02.2018
Сообщений: 117
01.06.2020, 19:03  [ТС]
DrType, Ругается в этом месте:
Миниатюры
Корзина на сайте  
0
Эксперт JS
 Аватар для DrType
6553 / 3624 / 1075
Регистрация: 07.09.2019
Сообщений: 5,877
Записей в блоге: 1
01.06.2020, 19:53
Андрэ1, это из-за того, что я не сделал проверку существования товара с данным идентификатором.
И там ещё есть огрехи, скоро исправлю.

Добавлено через 16 минут
В функции add можно просто добавить инструкцию
JavaScript
1
if(sort == undefined){return}
а можно переписать функцию так:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function add(id) {
  if (goods.some((product) => product.id == id)) {
    const sort = goods[goods.findIndex((product) => product.id == id)];
    if (sort.quant) {
      sort.quant--;
      if (!basket.some((product) => product.id == id)) {
        basket.push(sort);
        sort.bought++;
      }
    }
  } else {
    console.log("Мы таким не торгуем.");
  }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.06.2020, 19:53
Помогаю со студенческими работами здесь

Корзина
Всем привет! Вопрос, необходимо изменять текст в корзине, в зависимости от того, на какой категории находится пользователь. То есть в...

Корзина
Помогите написать простую карзину для HTML сайта, тоесть perl будет вставлен как скрипт. Корзина очень простая, мне нужно что бы под каждым...

Корзина
Доброго всем времени суток. У меня имеется магазин, который был первоначально написан для работы исключительно с $_SESSION. Просто...

Корзина
Привет народ! Срочно нужно сделать корзину для магазина, красивую! Надо чтоб при клике на кнопку "Корзина" - всё содержимое сайта...

Корзина
Задался я вопросом удалить все ярлыки с рабочего стола, установил рокетдок убралось всё кроме корзины, подскажите как убрать ярлык корзины...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru