doushe7934 2014-03-27 05:23
浏览 18
已采纳

使用ajax问题发送JSON数据

I have the following code:

var arr = {City:'Moscow', Age:25};

$.ajax({
    url: "<? echo $this->createUrl('cities/index');?>",
    type: "POST",
    data: JSON.stringify(arr),
    contentType: "application/json; charset=utf-8",
    dataType: "json",
    async: false,
    success: function(data){
        alert(data);
    }
});

The result is null. In the PHP side I have:

echo json_encode($_POST);

and

print_r($_POST);

But both are giving empty results (checked Firebug also).

  • 写回答

4条回答 默认 最新

  • doujing4555 2014-03-27 05:26
    关注

    I guess you don't need to stringyfy the data because data should be PlainObject or String but in your case you can simply write like below

    var arr = {City:'Moscow', Age:25};
    
           $.ajax({
                url: "<? echo $this->createUrl('cities/index');?>",
                type: "POST",
                data: arr,
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                async: false,
                success: function(data){
                    alert(data);
                }
            });
    

    as documented in jquery official site https://api.jquery.com/jQuery.ajax/

    data

    Type: PlainObject or String

    Data to be sent to the server. It is converted to a query string, if not already a string. It's appended to the url for GET-requests. See processData option to prevent this automatic processing. Object must be Key/Value pairs. If value is an Array, jQuery serializes multiple values with same key based on the value of the traditional setting (described below).

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 linux驱动,linux应用,多线程