jquery的ajax问题success:function(data)不执行

1.下面是struts.xml里的action信息<actionname="me"class="meAction"><resultname="success"><para... 1.下面是struts.xml里的action信息
<action name="me" class="meAction">
<result name="success">
<param name="root">users_json</param>
</result>
</action>

2.下面是action类(下面涉及到的get,set方法均齐全)
public String execute() {
System.out.println("*********");
Map<String, Object> map = new HashMap<String, Object>();
if(!"".equals(name_text)) map.put("name", name_text);
map.put("startIndex", 2);
map.put("endIndex", 4);
try {
records = queryUserService.getRecords("getRecordsNum",map);
users = queryUserService.getModels("me",map);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
String users_json = JSON.toJSONString(users);
System.out.println(users_json);
return "success";
}

3.通过ajax获得user_json字符串
<html>
<head>
<script type="text/javascript" src="../js/jquery-1.4.3.js"></script>
</head>
<body>
<form action="me" method="post">
用户名:<input type="text" id="name_text" name="name_text" />

密码:<input type="password" id="pwd_text" name="pwd_text" />

<input type="button" value="查询" id="sbt"/>
</form>
</body>
<script type="text/javascript">
$(document).ready(function(){
var name = $('#name_text').val();
var password = $('#pwd_text').val();
$("#sbt").click(function(){
alert("1111");
$.ajax({
type:"post",
url:"me",
data:"name="+name,
cache:false,
dataType:"string",
success:function(data) {
alert("fffff");
},
error:function(e) {
alert(e);
}
});
});
});
</script>
</html>
<!--叙述结束-->
success:function(data)这个方法不执行,执行的是error:function(e),我很纳闷,后台action已经执行了下面图片是后台执行后users_json的信息,信息都有了,后台应该没错的吧,请大侠帮我看看,为什么success:function(data)方法不执行
展开
 我来答
百度网友f4672095b
推荐于2017-11-26 · TA获得超过628个赞
知道小有建树答主
回答量:379
采纳率:80%
帮助的人:325万
展开全部
如果我没记错的话,$.ajax的datatype,没有string这一选项。
参考:http://api.jquery.com/jQuery.ajax/

String dataType
预期服务器返回的数据类型。如果不指定,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": 返回纯文本字符串
baiyukey
2013-10-29 · TA获得超过202个赞
知道小有建树答主
回答量:159
采纳率:0%
帮助的人:51.2万
展开全部
$.ajax({
type:"post",
url:"me",
data:{name:name},
cache:false,
success:successFnt,
error:errorFnt
}
function successFnt(){
alert("fffff");
}
function errorFnt(e) {
alert(e);
}

回调函数不能带参数,参数在data对象里传。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wwpswwps
2013-10-28 · TA获得超过360个赞
知道小有建树答主
回答量:154
采纳率:0%
帮助的人:148万
展开全部
在success: 上面一行加一个句“async:false”试试。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式