在ajax调用中传递参数

时间:2013-05-07 08:15:36

标签: asp.net ajax asp.net-mvc jquery asp.net-mvc-2

我正在尝试对控制器方法进行ajax调用。没有参数它工作正常。一旦我添加参数,我总是会收到一个空参数给cotroller。我想我已经正确地完成了传入ajax调用的参数。

 <script type="text/javascript">
        $(document).ready(function () {
            $('#lstStock').change(function () {
                var serviceURL = '<%= Url.Action("GetStockPrice", "Delivery") %>';
                var dropDownID = $('select[id="lstStock"] option:selected').val();
             alert(dropDownID); // here i get the correct selected ID
                $.ajax({
                    type: "POST",
                    url: serviceURL,
                    data: '{"stockID":"' + dropDownID + '"}',
                    contentType: "application/json; charset=utf-8",
                    dataType: "json",
                    success: successFunc,
                    error: errorFunc
                });

                function successFunc(data, status) {

                    alert(data.Result);


                }

                function errorFunc() {
                    alert('error');
                }
            })
        });
    </script>

控制器:

 [HttpGet]
        public ActionResult GetStockPrice()
        {
            return View();
        }

        [HttpPost]
        [ActionName("GetStockPrice")]
        public ActionResult GetStockPrice1(string stockID)//I get the null parameter here
        {
            DeliveryRepository rep = new DeliveryRepository();
            var value = rep.GetStockPrice(stockID);
            return Json(new { Result = value }, JsonRequestBehavior.AllowGet);

        }

3 个答案:

答案 0 :(得分:12)

这是因为您将数据视为字符串

data: '{"stockID":"' + dropDownID + '"}',

您可以将其更改为:

data: { stockID: dropDownID },

在某些情况下,根据控制器方法中声明的参数,您需要序列化数据。如果你需要这样做,那么你就是这样做的:

var o = { argName: some_value };
$.ajax({
    // some other config goes here
    data: JSON.stringify(o),
});

答案 1 :(得分:3)

尝试data: { stockID : dropDownID},

$('#lstStock').change(function () {
    var serviceURL = '<%= Url.Action("GetStockPrice", "Delivery") %>';
    var dropDownID = $('select[id="lstStock"] option:selected').val(); 
                     // $(this).val(); is better
         alert(dropDownID); // here i get the correct selected ID
            $.ajax({
                type: "POST",
                url: serviceURL,
                data: { stockID : dropDownID},
                ....

答案 2 :(得分:2)

尝试指定:

data: { stockID : dropDownID },

看起来你是"stockID"而不是stockID。 Fiddler是一个很好的工具,它可以让你看看Controller的动作是否被击中以及向服务器发送了什么数据。