嗨,我有以下HTML代码:
<li class="grey">
<div class="row">
<button id="test" style="width:50%;" class="btn btn-blue-white cartBtn">Add to Cart</button>
</div>
<div class="row">
<a href="#" class="checkoutLink" style="margin-top:-10px;font-size:small">Go To Checkout</a>
</div>
</li>
当我加载页面时,我隐藏了结帐链接按钮,直到用户点击“添加到购物车”。点击添加到购物车后我的javascript看起来像这样:
$('.cartBtn').click(function () {
//do stuff for preprocessing
var url = "../Store/AddToCart";
$.ajax({
type: "GET",
url: url,
data: {
//add data
},
dataType: "json",
success: function (data) {
if (data.success == true) {
$(this).closest('li').find('.checkoutLink').show();
}
}
});
});
链接永远不会显示回来。我也试过用
$(this).parent().parent().find('.checkoutLink').show()
同样也没有运气。我如何使用jquery获取此锚标记并使其可见。
问题是this
,当从成功函数中调用时,它不再引用外部this
。在Ajax之外创建一个引用原始this
的变量。
$('.cartBtn').click(function () {
var $this = $(this);
//do stuff for preprocessing
var url = "../Store/AddToCart";
$.ajax({
type: "GET",
url: url,
data: {
//add data
},
dataType: "json",
success: function (data) {
if (data.success == true) {
$this.closest('li').find('.checkoutLink').show();
}
}
});
});