探讨.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>