div中的嵌套按钮

时间:2018-02-04 22:19:33

标签: javascript jquery html asp.net twitter-bootstrap

情况如下。我有一个盒子,它是一个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>
}

1 个答案:

答案 0 :(得分:0)

在处理内部div的click事件的函数中,通过在事件上调用event.stopPropagation()来阻止事件传播到外部div:

function clickHandler(event) {
  event.stopPropagation();

  // Do your other stuff like Ajax calls
}