Я использую Jquery в частичном представлении для передачи данных контроллеру. Вот мой код частичного вида:Получение нулевого значения в JQuery в частичном представлении
@model List<Apostille.Models.Cart>
@{
var grid = new WebGrid(source: Model, canPage: true, rowsPerPage: 10);
grid.Pager(WebGridPagerModes.All);
}
@using (Html.BeginForm("MinusQuantity", "Cart", FormMethod.Post, new { id = "myForm" }))
{
<div>
@grid.GetHtml(
tableStyle: "webgrid-table",
headerStyle: "webgrid-header",
footerStyle: "webgrid-footer",
alternatingRowStyle: "webgrid-alternating-row",
selectedRowStyle: "webgrid-selected-row",
rowStyle: "webgrid-row-style",
mode: WebGridPagerModes.All,
columns: grid.Columns(
grid.Column(columnName: "country_name", header: "Country Name"),
grid.Column(columnName: "state_name", header: "State Name"),
grid.Column(columnName: "document_title", header: "Document Title"),
grid.Column(columnName: "document_name", header: "Document Name"),
grid.Column(header: "Document Quantity", format: @<div><button onclick="minus(@item.order_id,@item.number_of_document)" data-type="minus" class="btn btn-danger btn-number" data-field="number_of_document"><b>-</b></button> <span style="margin-left: 18%">@Html.Raw(@item.number_of_document)</span> <button onclick="plus(@item.order_id,@item.number_of_document)" data-type="plus" class="btn btn-success btn-number" data-field="number_of_document", style="float:right"><b>+</b></button></div>),
grid.Column(columnName: "first_doc_price", header: "First Doc Price"),
grid.Column(columnName: "addition_doc_price", header: "Additional Doc Price"),
grid.Column(columnName: "extra_total", header: "Addtional Doc Total"),
grid.Column(columnName: "total", header: "Final Total")
//grid.Column(format: (item) => Html.ActionLink("Edit", "_EditCartPartial", new { @id = "send id here" }))
))
</div>
}
<script type="text/javascript">
jQuery(document).ready(function() {
alert("DOM loaded!");
function minus(orderId, qty) {
$.ajax({
url: '@Url.Action("MinusQuantity", "Cart")',
dataType: "json",
contentType: "application/json; charset=utf-8",
data: { 'OrderId': orderId, 'Quantity': qty },
sucess: function (data) {
}
})
}
});
//alert("this script tag is executing properly!");
function plus(orderId, qty) {
$.ajax({
url: '@Url.Action("PlusQuantity", "Cart")',
dataType: "json",
contentType: "application/json; charset=utf-8",
data: { 'OrderId': orderId, 'Quantity': qty },
sucess: function (data) {
}
})
}
</script>
Я могу назвать JQuery успешно, но я получаю нулевое значение в OrderID и QTY, когда я нажмите кнопку для WebGrid.
Я читал где-то, что jquery не работает в частичном представлении, поэтому я попытался поместить jquery в index.cshtml, но все же я получил нулевое значение для обоих этих.
Однако, если я перемещаю webgrid в index.html, jquery работает все нормально.
Какая возможная причина, что jquery не работает на частичном изображении? что я должен сделать, чтобы преодолеть этот сценарий?
Спасибо за ответ –