var summ;
function selectItem(id) {
summ += Number($('#item-' + id).attr('data-price'));
$('#summ').text(summ);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="block1">
<div class="item-1" onclick="selectItem(1);" data-price="10" >selectItem(1)</div>
<div class="item-2" onclick="selectItem(2);" data-price="20" >selectItem(2)</div>
</div>
<br>
summ: <div id="summ"></div>
Код должен считать сумму по атрибуту data-price
, но почему-то отдает NaN
summ
.item-
, а не идентификатор #item-
var summ = 0;
function selectItem(id) {
summ += Number( $('.item-' + id).data('price') );
$('#summ').text(summ);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="block1">
<div class="item-1" onclick="selectItem(1);" data-price="10" >selectItem(1)</div>
<div class="item-2" onclick="selectItem(2);" data-price="20" >selectItem(2)</div>
</div>
<br>
summ: <div id="summ"></div>
В данном случае не инициализирована переменная summ. Ее значение по умолчанию - undefined.
Результат сложения undefined с любым числом даст NaN.
Как верно заметил @GlebKemarsky разметке присутствуют элементы с классом, а в функции ищутся элементы с id. Из-за этого,
$('#item-' + id).data('price')
Вернет undefined, и Number(undefined)
даст NaN
.
Виртуальный выделенный сервер (VDS) становится отличным выбором
После наведения мыши на одно изображение ховер эффект воспроизводиться и на всех остальныхКак сделать, чтобы ховер (белый блок с текстом...
Привет! Хочу добавить эффект фэйдинга чтобы, когда прокручиваешь страницу вниз элементы начинали появлятьсяНа данный момент в скрипте есть
Подскажите, почему в IE 11 отображаются не такие шрифты как надо? Можно ли это как-то исправить?