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)方法不执行 展开
<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)方法不执行 展开
3个回答
展开全部
如果我没记错的话,$.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": 返回纯文本字符串
参考: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": 返回纯文本字符串
展开全部
$.ajax({
type:"post",
url:"me",
data:{name:name},
cache:false,
success:successFnt,
error:errorFnt
}
function successFnt(){
alert("fffff");
}
function errorFnt(e) {
alert(e);
}
回调函数不能带参数,参数在data对象里传。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在success: 上面一行加一个句“async:false”试试。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询