weixin_52192654
画_船_听_雨
采纳率100%
2021-05-07 13:00 阅读 30
已采纳

jQuery ajax的datatype,dataType,dataTypes有什么区别。

控制器类

/**
     * 根据id查询管理员信息的请求处理方法
     * @param id
     * @return
     */
    @RequestMapping(value = "/select.do")
    public AdminBean findOne(Integer id){
        AdminBean adminBean = adminBeanService.findOne(id);
        return  adminBean;
    }

ajax发送请求

  //    测试查询
            $("#but4").click(function () {
                $.ajax({
                    url:"adminBean/select.do?id=1",
                    type:"GET",
                    datatype:"json",
                    // dataType:"json",
                    // dataTypes:"json",
                    contentType:"application/json",
                    success:function (response) {
                        // alert(response);
                        console.log(JSON.stringify(response));
                    }
                })
            })

在查询的数据没有时,控制器类返回一个空对象null,前端接收的数据使用 datatype和dataTypes可以得到""空字符串,而使用dataType则没有反应。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

5条回答 默认 最新

  • 已采纳
    technologist_16 CSDN专家-天际的海浪 2021-05-07 17:52

    ajax 没有datatype,dataTypes这两个参数,只有dataType参数 
    dataType的默认值是"text",表示返回数据按纯文本字符串处理。你可以得到""空字符串就是dataType的值是"text"
    如果 dataType:设置"json" 会在ajax方法内部调用JSON.parse()把字符串转换成js的对象或数组,
    这就要求字符串符合json格式,不能是""空字符串。

    在查询的数据没有时,应该返回一个空对象 "{}" 或者 空数组 "[]" ,也可以返回 "null"字符串,  但是不能返回""空字符串,否则就会出错。
     

    点赞 1 评论 复制链接分享
  • software7503 CSDN专家-赖老师(软件之家) 2021-05-07 13:06

    正确使用应该就是dataType,得到空字符串是错误的,应该返回一个对象object

    点赞 评论 复制链接分享
  • QA_Assistant 有问必答小助手 2021-05-07 13:25

    您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

    如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

    ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

    点赞 评论 复制链接分享
  • showbo GoCityPass新加坡曼谷通票 2021-05-07 13:42

    json属性是大小写敏感的,datatype和dataType不是同一个属性。dataType才是jquery ajax正确配置属性,表示预期服务器返回的数据类型,success回调参数会转为指定的类型。转换失败success不会执行

    dataType

    类型:String

    预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:

    • "xml": 返回 XML 文档,可用 jQuery 处理。
    • "html": 返回纯文本 HTML 信息;包含的 script 标签会在插入 dom 时执行。
    • "script": 返回纯文本 JavaScript 代码。不会自动缓存结果。除非设置了 "cache" 参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的 script标签来加载)
    • "json": 返回 JSON 数据 。
    • "jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。
    • "text": 返回纯文本字符串
    点赞 评论 复制链接分享
  • QA_Assistant 有问必答小助手 2021-05-08 14:56

    非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

    速戳参与调研>>>https://t.csdnimg.cn/Kf0y

    点赞 评论 复制链接分享

相关推荐