jquery 的ajax请求 之都是 dataType 缺失惹的祸

  事情的起因:做一个简单的权限登录界面,涉及到通过页面发送异步1请求来校验验证码的功能:

    

$.ajax({
			type : "post",
			url : "./login.do",
			data : {
				
				account : account,
				passWord : passWord,
				code : code
			},
			//请求成功后的回调函数有两个参数
			success : function(data, textStatus) {
				if (data.status != 0) {
					$("#message").text(data.msg);
				} else {
					window.location = "./index";
				}
			},
			error : function(data, textStatus) {
				$("#message").text(data.msg);
			}
		});

  故意输入错误的验证码,得到服务器返回的json数据,页面上本该出现错误提示信息,然而一直没有出现,然后用页面debug,发现页面接收到了服务器端返回的json数据

{"status":1,"msg":"验证码输入错误","data":null}

,很奇怪没错啊,继续用debug,发现data.msg 为undefined,纳闷了,搞了很久,最后发现返回的数据类型是text/plain,原来是自己少写了一个希望服务器返回的数据类型dataType: "json", 默认接收类型为字符串。

改正后的代码:

$.ajax({
			type : "post",//请求方式
			url : "./login.do",//发送请求地址
			dataType: "json",
			contentType: "application/json; charset=utf-8",
			data : {
				account : account,
				passWord : passWord,
				code : code
			},
			//请求成功后的回调函数有两个参数
			success : function(data, textStatus) {
				if (data.status != 0) {
					$("#message").text(data.msg);
				} else {
					window.location = "./index";
				}
			},
			error : function(data, textStatus) {
				$("#message").text(data.msg);
			}
		});

  其中几个参数的含义在巩固一下

  type:请求方式,又称Method

  dataType:预期返回类型(The type of data that you're expecting back from the server)

  contentType:发送到服务器的数据的编码类型(When sending data to the server, use this content type)

  data:发送到服务器的数据

总结:温故而知新,知识需要不断的重复,遇到问题认真分析原因~

转载于:https://my.oschina.net/jamescasta/blog/650931

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值