0

Я использую 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 не работает на частичном изображении? что я должен сделать, чтобы преодолеть этот сценарий?

ответ

0

использование ParseInt

function minus(orderId, qty) { 
      var ordId = parseInt(orderId); 
      var quant = parseInt(qty); 
      $.ajax({ 
       url: '@Url.Action("MinusQuantity", "Cart")', 
       dataType: "json", 
       contentType: "application/json; charset=utf-8", 
       data: { 'OrderId': ordId , 'Quantity': quant}, 
       sucess: function (data) { 

       } 
      }) 
     } 
+0

Спасибо за ответ –