为了账号安全,请及时绑定邮箱和手机立即绑定

为什么回调函数中收到的data值是一个document对象而不是我想要的那个str字符串呢?

为什么回调函数中收到的data值是一个document对象而不是我想要的那个str字符串呢?

慕容708150 2023-02-17 21:17:59
java代码: public class AjaxAction extends ActionSupport { public void getDept() { (中间省略,只写了处理结果) String str={"1":{"Dname":"光电信息科学技术学院"},"2":{"Dname":"化学化工学院"}}; out.println("str"); out.close(); } } struts.xml代码: <action name="getDept" class="AjaxAction" method="getDept"> </action> js代码 $(document).ready(function getDept() { $.get("getDept", null, function (data) { var obj = eval(data); }) }); 
查看完整描述

3 回答

?
UYOU

TA贡献1878条经验 获得超4个赞

你用json格式 把 string类型封装成 对象,然后再把json对象解析为 string类型,这样应该就OK了吧,。
function checkExist(){
//使用 Ajax 的方式 判断数据库中是否有该用户的名字(注册的时候)
alert($("#name").val());
$("#nameW").empty();
var url = "regiValiAndLoginAjax!isNameExist";
//获取表单值,并以json的数据形式保存到params中
var params = {name:$("#name").val()}
//使用$.post方式 
$.post(
url, //服务器要接受的url
params, //传递的参数 
function cbf(data){ //服务器返回后执行的函数 参数 data保存的就是服务器发送到客户端的数据
//alert(data);
var member = eval("("+data+")"); //包数据解析为json 格式  
isExist = member.nameExist;
if(member.nameExist == "false"){
isNameT = "true";
namePass = true;
//$("div[id!='nameW4']").empty();
alert("恭喜你,用户名可用的啦");
$("#nameW4").show("slow");
$("#nameW3").hide("slow");
$("#name").attr("disabled", true);
$("nameW1").css("color", "#333333");

}
else{
alert("用户名已存在,请重新输入");
namePass = false;
$("#nameW3").show("slow");
$("#nameW4").hide("slow");
isNameT = "false";
}
}, 
"json" //数据传递的类型 json
);
}

上面是 jsp 的页面代码:
下面是java中的代码;
//以下是ajax的访问的方法开始
public String isNameExist(){//判断用户的注册名在数据库中是否存在的 啦

vali = new Validation();
name = this.getName();
System.out.println("userName = " + name);
boolean exist = false;
String isExist = "false";
try {
exist = this.userService.existsName(name);
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
if(exist){
isExist = "true";
}else{
this.getSession().put("name", this.getName());
System.out.println(this.getSession().get("name").toString());
}
vali.setNameExist(isExist);
JSONObject jo = JSONObject.fromObject(vali);
result = jo.toString();
System.out.println(result);
return SUCCESS;
}
其实json格式对数据的封装是很方便的,,ajax + jquery + json 应该是完美的搭配吧 

 


查看完整回答
反对 回复 2023-02-20
?
森栏

TA贡献1810条经验 获得超5个赞

1:out.println("str"); //去掉引号
2:var obj = eval(data); //在这里你把data值转换成了对象
如果要直接返回str:var obj = data;

查看完整回答
反对 回复 2023-02-20
?
SMILET

TA贡献1796条经验 获得超4个赞

$.get("getDept", null, function (data) { 
var obj = eval(data); 
},json)

查看完整回答
反对 回复 2023-02-20
  • 3 回答
  • 0 关注
  • 140 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号