js获取另一个jsp页面上的json数据

有两种方法,一种是$.ajax(option)方法,一种是$.getJSON()方法。

实例:

一、数据集所在jsp页面out.jsp,代码如下

<%@page contentType="text/plain; charset=UTF-8"
language="java"
import="java.io.*,java.net.*,java.util.*"
buffer="8kb"
session="false"
autoFlush="true"
%>
<%

String jsonData="{data:[{id:200901,name:'name1'},{id:200902,name:'name2'},{id:200903,name:'姓名3'},{id:200904,name:'姓名4'},{id:200905,name:'姓名5'}]}";
//out.clear();
out.write(jsonData);
%>

二、js处理页面

(1)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>test</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>

<script type="text/javascript" language="javascript" src="js/jquery.js"></script>

<script type="text/javascript">
function getOut(){
    var s='';
    $.ajax({
        type:'get',//请求方式
        url:'out.jsp?id='+Math.random(), // AJAX HTTP请求接口
        data:'',//提交到服务器接口的参数 比如'{cid:0405}',结果为out.jsp?cid=0405格式
        dataType:'json',//请求类型为json, 更多见jquery doc文档
        timeout:7000,//请求超时后停止请求
        success: function(json){
         var d=json.data;
            $.each(d,function(i){
                s+=('<p>id:'+d[i].id +'&nbsp;&nbsp;|&nbsp;&nbsp;name:'+d[i].name+'</p><hr/>');
            });
            $('#out').html(s);}});
    }
</script>
</head>
<body style="margin:20px;text-align:center;background:#E5E5E5;">

<input type="text" name="getdata"  onclick="getOut()"/>
<div id="out">
</div>

</body>
</html>

(2)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<%@ page language="java" contentType="text/html; charset=utf-8"%>

<head>

<script type="text/javascript" src="js/jquery-1.3.2.min.js"></script>
<script>
 function showStudent(){
     var s='';
  $.getJSON("out.jsp?id="+Math.random(),function(json){
   var d=json.data;
  for(var i=0;i<d.length;i++){
    s+=('<p>id:'+d[i].id +'&nbsp;&nbsp;|&nbsp;&nbsp;name:'+d[i].name+'</p><hr/>');
  }
  $('#content').html(s);
 });
 
}

 </script>
</head>
<body>
<input type="button" value="获取学院信息" onclick="showStudent()" />
<div id="content"></div>
</body>
</html>

总结:

(1)自己在做的时候,总是出现错误,原因在于——json数据格式有问题,前端$.getJSON()方法并没有什么错误。

(2)相对来说,$ajax(option)方法使用比较灵活,可以用在比较复杂的情况。

posted on 2012-04-21 14:28  笑靥  阅读(3905)  评论(0编辑  收藏  举报