по клику на кнопку “В корзину” должен запустится скрипт (action) который добавляет $product['id'] в сессию. Работало все штатно и я, осознанно, ничего не менял, но…перестал отрабатываться этот клик. Если убрать class - работает. CSS дефолтный bootstrap
Смотрю в Devtools-Network, а по клику запускается js: cart/addAjax/undefined
<script>
$(document).ready(function(){
$(".add-to-cart").click(function () {
var id = $(this).attr("data-id");
$.post("/cart/addAjax/"+id, {}, function (data) {
$("#cart-count").html(data);
});
return false;
});
});
</script>
т.е. js по клику на элементе с классом add-to-cart берет значение аттрибута data-id и передает его по ссылке. Но почему undefined, если аттрибут data-id имет значение?
Так получилось что на одну кнопку 2 действия прописано: синхрон /cart/add/ и асинхрон /cart/addAjax. И как узнать кто из них в приоритете запуска?
return false from within a jQuery event handler is effectively the same as calling both e.preventDefault and e.stopPropagation on the passed jQuery.Event object.
e.preventDefault() will prevent the default event from occuring, e.stopPropagation() will prevent the event from bubbling up and return false will do both. Note that this behaviour differs from normal (non-jQuery) event handlers, in which, notably, return false does not stop the event from bubbling up.
результат должен вставится на страницу в html елемента #cart-count. Ok. Перерисовка(обновление) автоматически будет или тригер какой-то нужен?
Я ожидаю, например,