探讨.get .post .ajax ztree 还有后台servlet传递数据的相关知识
servlet给前台传递data串
用的方法是
PrintWriterout=response.getWriter(); //response.sendRedirect("test.jsp"); Strings="[{'id':'1','pId':'0','name':'test1'},{'id':'11','pId':'1','name':'test11'},{'id':'12','pId':'1','name':'test12'},{'id':'111','pId':'11','name':'test111'},]"; out.write(s);
----------------------
关于.get.post.ajax的浅显的理解是
最后一个是异步的,前面两个是同步的(阻塞的)
.get(url,data,function(data,status){ 执行的函数 //我理解的data和url参数的意思是一样的 })
-------------------------
ztree的使用:
注意ztree两种json的格式的区别,经常使用的是简单的格式是,直接通过数据之间的关系显示树的结构
第二种是通过的是json的潜逃实现的
注意的是样式和js文件必须是引入全的然后是界面上的位置是ul
然后是
//注意的话是传递response传递回来的类型是string,这是string转换对象的方法 varss=eval("("+data+")"); vart=$("#test"); //然后是树控的初始化(位置,配置,数据) t=$.fn.zTree.init(t,setting,ss); //取得树对象然后操作 varzTree=$.fn.zTree.getZTreeObj("test");
收集整理,关于后台的数据传往前台的问题解决
关于
.get替换成
.ajax $("button").click(function(){ $.get("demo_ajax_load.txt",function(result){ $("div").html(result); }); });------------$.ajax({url:url,data:data,success:success,dataType:dataType});
ps:AJAX使用POST方法向后台Servlet传递数据的方法
<scripttype="text/javascript"> //统计资源访问次数的脚本 //定义XMLHttpRequest对象 varhttp_request=false; functionsend_request(url,rewriteUrl){ http_request=false; //开始初始化XMLHttpRequest对象 if(window.XMLHttpRequest){//Mozilla等浏览器初始化XMLHttpRequest过程 http_request=newXMLHttpRequest(); //有些版本的Mozilla浏览器处理服务器返回的未包含XMLmime-type头部信息的内容时会出错. //因此,要确保返回的内容包含text/xml信息. if(http_request.overrideMimeType){ http_request.overrideMimeType("text/xml"); } } elseif(window.ActiveXObject){//IE浏览器初始化XMLHttpRequest过程 try{ http_request=newActiveXObject("Msxml2.XMLHTTP"); } catch(e){ try{ http_request=newActiveXObject("Microsoft.XMLHTTP"); } catch(e){} } } //异常,创建对象失败 if(!http_request){ window.alert("不能创建XMLHttpRequest对象实例!"); returnfalse; } //指定响应处理函数 http_request.onreadystatechange=processRequest; //发送HTTP请求信息 http_request.open("POST",url,true); http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //将参数放到这里,后台servlet可以用request.getParameter()方法取到这些参数 http_request.send("rewriteUrl="+rewriteUrl"&rewriteUrl2="+rewriteUrl2); } //处理返回信息函数 functionprocessRequest(){ //判断对象状态 if(http_request.readyState==4){ //判断HTTP状态码 if(http_request.status==200){ //信息已经成功返回,无动作 } else{ //请求页面有问题 alert("您所请求的页面有异常!错误状态:"+http_request.status); } } } functiondosearch(rewriteUrl){ send_request("http://127.0.0.1:8000/);//这里的rewriteUrl就是页面上放置的资源经过重写后的链接 } //统计资源访问次数的JS——end </script>
另外,页面上放置重写地址的元素需要调用上面的dosearch(rewriteUrl)方法,将重写后的链接当作参数传递给这个方法,例如:
<ahref="http://127.0.0.1:8000/iras50/rewriter/CNKI/"target="_blank"onclick="dosearch('http://127.0.0.1:8000/iras50/rewriter/CNKI/');">中国知网</a>