时间:2021-05-26
这篇文章主要介绍了Servlet返回的数据js解析2种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
方式1:Json
接收函数:ajax.responseText后面没括号
其实在之前所说的ajax中还遗留了一些问题就是,Servlet返回给js的数据是如何被js解析的呢?
之前只是发送了一句话,所以他就以html的格式进行解析就成功了,但是在实际中我们往往发送的数据是存在一个对象当中的又或者是一组对象当中的,我们应该如何发送呢?
json:js当中有一种有一种结构就是json,说白了就是键值对。
例如下面的:
{ "firstName":"John" , "lastName":"Doe" }我们可以在Servlet将属性与值进行拼接,得到json格式的字符串,这样js中就能以这样的格式进行数据的解析了。
类似于下面这样:
resp.getWriter().write("{name:"+u.getHeroName()+ ",lifenum:"+u.getLifeNum()+ ",type:"+u.getType()+ ",desc:"+u.getDesc() +"}")但是对于懒癌来说这样的方式是极不友好的,所以就要说到强大的jar包了。
有一款名为gson的jar包可以帮你完成拼接的工作
对于使用就是你直接将对象丢进去就好,它会自动帮你转为json格式。
然后又有问题来了,json的数据给js有什么用,我们一般操纵的是对象呀!
别慌,eval帮你解决
方式2:XML进行解析
接收函数:ajax.responseXML后面没括号
可以将用户数据以Xml进行发送然后js也以xml格式解析
用户数据的xml可以写在jsp中,然后js的跳转(open函数)就不用跳转到Servlet中而是jsp中找用户数据
用户数据jsp:
<%@ page language="java" contentType="text/xml; charset=utf-8"%><user> <name>李四</name> <pwd>123</pwd></user>ajax接收数据jsp
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><script type="text/javascript"> function getXML(){ //创建ajax引擎对象 var ajax; if(window.XMLHttpRequest){//火狐 ajax=new XMLHttpRequest(); }else if(window.ActiveXObject){//ie ajax=new ActiveXObject("Msxml2.XMLHTTP"); } //复写onreadystatechange ajax.onreadystatechange=function(){ //判断Ajax状态吗 if(ajax.readyState==4){ //判断响应状态吗 if(ajax.status==200){ //获取响应内容 var doc=ajax.responseXML; //处理响应内容 //获取元素对象 alert(doc.getElementsByTagName("name")[0].innerHTML); } } } //发送请求 ajax.open("get","xml.jsp",true); ajax.send(null); }</script></head><body> <h3>XML数据格式学习</h3> <hr> <input type="button" value="测试XML" onclick="getXML()" /> </body></html>但是这种方式没有json好,所以推荐用json方式进行进行解析会更好一点。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
实现Servlet程序的三种方法1.手动实现Servlet程序1.编写一个类去实现Servlet接口2.实现service方法,处理请求并响应数据示例代码://
原因:servlet返回的数据不是Json格式1、JS代码为:varjsonStr={'clusterNum':2,'iterationNum':3,'runT
在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式:1.一种为使用eval()函数。2.使用Function对象来进行返回解析。第一种解析方式:使
在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式:1.一种为使用eval()函数。2.使用Function对象来进行返回解析。使用eval函数来
响应数据和结果视图返回值分类controller方法返回字符串可以指定逻辑视图名,通过视图解析器解析为物理视图地址。//指定逻辑视图名,经过视图解析器解析为js