解决方法是关闭response的writer。
下面是ajax代码
$j.ajax({
type : "POST",
url : "/asi/jsonCarrier.jsp",
data : {"artistId":"${artistID}"}, //这里从session里拿出了artistID变量,用的是el表达式
datatype : "text",
timeout: 10000,
success : function(data) {
if (data!="" &&data!=null){
var dataArr = data
var jsonData = dataArr.statistics
var priceData = []
var volumeData = []
var summaryData = []
$j.each(jsonData, function(i, dataItem) {
priceData[i] = [ i, dataItem.beta ]
volumeData[i] = [ i, dataItem.volume ]
summaryData[i] = [ i, dataItem.volatility ]
})
$j("#artistName").html(dataArr.meta.artist_forename+" "+dataArr.meta.artist_surname)
displayGraph(jsonData, priceData, volumeData, summaryData)
}
},
error : function(XMLHttpRequest, textStatus, errorThrown){
alert(textStatus)
}
})
下面是 jsonCarrier.jsp里的java代码
<%
String artistId = request.getParameter("artistId")
String jsonData = DBSightXmlUtil.getXmlFromServer("http://aaa.com/json/asi-artist-"+ artistId + "-y.json")
response.setContentType("application/json")
response.getWriter().flush()
response.getWriter().write(jsonData)
response.getWriter().close() //这里就是关键
%>
将HTML和JS分开加载,写一个全局的方法,在获取html后查找其中的脚本文件重新加载如:获取HTML并加载后
可以用以下方式加载JS
var _obj = ...// 这里是你加载html的对象,没用jQuery
var scriptTags = _obj.getElementsByTagName("script")
for (var i = 0i <scriptTags.lengthi ++){
if(scriptTags[i].src == null || scriptTags[i].src == "")
new Funtion(scriptTags.innerHTML)()
else{
var s = document.createElement("script")
s.src = scriptTags[i].src
document.body.appendChild(s)
}
}
这样,所有的HTML中内嵌的js就都能执行了
大的方向确实是路径问题,通常项目中公司会对前端请求的路径做一个后缀名称的验证。如:正常的接口=》queryMeetingList.ajax 但在请求时我们公司要改成queryMeetingList.webApp才行。具体每个公司怎么处理都不同。不过大的方向可以说是路径问题。