Javascript-форум (https://javascript.ru/forum/)
-   jQuery (https://javascript.ru/forum/jquery/)
-   -   Как преобразовать счетчик к нужному виду? (https://javascript.ru/forum/jquery/56557-kak-preobrazovat-schetchik-k-nuzhnomu-vidu.html)

ligisayan 22.06.2015 18:06

Как преобразовать счетчик к нужному виду?
 
Всем привет. У меня есть счетчик, подсчитывающий количество и сумму конкретной продукции. В span с классом quantity хранится количество и сумма в виде "13 x 70 руб." input c type="number" должно получать значение quantity, т.е. цифру 13. input c type="button" увеличивают/уменьшают значение переменной input c type="number", что должно также отражаться в quantity, а сумма в amount перезаписываться в полном виде, т.е. сумма= 13*70 = 910 руб Сложность в преобразовании строк в значения и в автоматическом отслеживании изменений с обменом информации между селекторами. В коде написал смысл того, что хочу получить. Поможете в преобразовании?
<span class="quantity">13 × <span class="amount">70&nbsp;руб.</span></span>
<div class="quantity buttons_added">
  <input type="number" step="1" min="1" max="27" id="num_count" name="quantity" value="1" title="Кол." class="input-text qty text" size="4">
  <input type="button" value="+1" id="button_plus" class="plus">
  <input type="button" value="-1" id="button_minus" class="minus">
</div>

var quantity = $(".quantity").text();
$(".input-text.qty.text").val(quantity);
var amount = $(".amount").text();
var total = amount * quantity;
$(".quantity").text() = $(".input-text.qty.text").val(quantity);
$(".amount").text() = total;

рони 22.06.2015 21:04

ligisayan,
может использовать data атрибут для хранения констант, а не текст?

ligisayan 22.06.2015 22:25

Цитата:

Сообщение от рони (Сообщение 376110)
ligisayan,
может использовать data атрибут для хранения констант, а не текст?

я бы вмешался в разметку, но она с помощью виджета выводится

рони 22.06.2015 22:35

ligisayan,
а виджет инициализирует злой волшебник :cray:
<!DOCTYPE HTML>

<html>

<head>
  <title>Untitled</title>
  <meta charset="utf-8">
  <style type="text/css">
  .amount {
    color: #FF0000;
  }

  </style>
  <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
  <script>
  $(function() {
      var quantity = $(".quantity").text().match(/\d+/g),
          max = +$(".input-text.qty.text").attr("max"),
          min = +$(".input-text.qty.text").attr("min");

      function fn() {
          quantity[0] > max && (quantity[0] = max);
          quantity[0] < min && (quantity[0] = min);
          $(".input-text.qty.text").val(quantity[0]);
          $(".amount").text(quantity[1] + " " + (quantity[0] * quantity[1]) + "  руб");
          $(".quantity")[0].firstChild.data = quantity[0] + " × ";
      }
      $(".plus, .minus").click(function() {
          $(this).is(".plus") ? quantity[0]++ : quantity[0]--;
          fn()
      })
      $(".input-text.qty.text").click(function() {
          quantity[0] = this.value;
          fn()
      })
      fn()
  });
  </script>
</head>

<body>  <span class="quantity">13 × <span class="amount">70&nbsp;руб.</span></span>
<div class="quantity buttons_added">
  <input type="number" step="1" min="1" max="27" id="num_count" name="quantity" value="1" title="Кол." class="input-text qty text" size="4">
  <input type="button" value="+1" id="button_plus" class="plus">
  <input type="button" value="-1" id="button_minus" class="minus">
</div>


</body>

</html>

ligisayan 23.06.2015 11:51

Цитата:

Сообщение от рони (Сообщение 376123)
ligisayan,
а виджет инициализирует злой волшебник :cray:

рони, супер! только осталось еще разобрать 2 момента: если у меня цифры измеряются в тысячах и миллионах, то явно .match(/\d+/g)
недостаточно.
и второй момент у меня: если нажимаешь на "+" то прибавляет на 1, а если на "-" то сразу уменьшает на 3 единицы, а потом по одному и после, если вновь жмешь на "+" то сразу прибавляет на 3, а потом на 1. Это отчего так? у тебя в примере так не происходит..

рони 23.06.2015 12:27

Цитата:

Сообщение от ligisayan
если у меня цифры измеряются в тысячах и миллионах, то явно .match(/\d+/g)
недостаточно.

почему?
Цитата:

Сообщение от ligisayan
то сразу прибавляет на 3,

а целом это жуткий костыль, придёт бабайка ругать будет, шаг влево шаг вправо растрел на месте вон у вас уже 3 выскочило :)
что у вас в коде мне неизвестно :)

ligisayan 23.06.2015 13:37

Цитата:

Сообщение от рони (Сообщение 376180)
почему?

а целом это жуткий костыль, придёт бабайка ругать будет, шаг влево шаг вправо растрел на месте вон у вас уже 3 выскочило :)
что у вас в коде мне неизвестно :)

ну, например сумму "360.000&nbsp;руб."
var quantity = $(".li .quantity").text().match(/\d+/g)
в консоли показало
["1", "360", "000"]

рони 23.06.2015 13:42

ligisayan,
match(/\d+.?\d+?/g)

ligisayan 23.06.2015 13:58

Цитата:

Сообщение от рони (Сообщение 376196)
ligisayan,
match(/\d+.?\d+?/g)

рони не лучше

рони 23.06.2015 14:13

ligisayan,
и что не так?


Часовой пояс GMT +3, время: 02:20.