情况如下。我有一个盒子,它是一个div,包含另一个div,基本上是一个按钮。单击外框时,它应重定向到产品详细信息页面。单击框中的按钮时,它应执行ajax调用,将该特定项添加到购物车。
目前,当点击外框时,它会重定向到产品详细信息页面,这是所需的功能。但是,当单击内部按钮时,它会添加到购物车并重定向,而我不希望它重定向但只是添加到购物车。如何实现所需的功能?
以下是asp.net的代码
@using LaptopMart.Models
@model IEnumerable<LaptopMart.Models.Product>
@{
ViewBag.Title = "User Index";
}
<h2>title</h2>
@foreach (Product product in Model)
{
<div class="inline">
<div class="A" div-product-id ="@product.Id">
<div class="card">
<div class="card-head">
<img src="~/Content/ProductImages/@product.Image" alt="product-image" class="card-product-image">
</div>
<div class="card-body">
<div class="product-details">
<span class="product-title">@product.Name</span>
<span class="product-price">$<b>@product.Price</b></span>
</div>
<div>
<div class="btn-sm btn-primary js-add-to-cart" data-product-id="@product.Id" >Add to Cart</div>
</div>
</div>
</div>
</div>
</div>
}
@section scripts
{
<script>
$(document).ready(function () {
$(".A").on("click", function () {
if ($(this).hasClass("js-add-to-cart")) {
return;
}
else {
window.location.href = "/user/ProductDetails/" + $(this).attr("div-product-id");
}
});
$(".js-add-to-cart").on("click",
function () {
var button = $(this);
$.ajax({
url: "/api/user/AddToCart/" + button.attr("data-product-id"),
method: "GET",
success: function () {
window.setTimeout(function () {
bootbox.hideAll();
}, 1000);
bootbox.alert("This has been added to cart");
}
});
});
});
</script>
}
答案 0 :(得分:0)
在处理内部div
的click事件的函数中,通过在事件上调用event.stopPropagation()
来阻止事件传播到外部div:
function clickHandler(event) {
event.stopPropagation();
// Do your other stuff like Ajax calls
}