Jquery通过ajax请求NodeJS返回json数据实例
最近看了NodeJS相关的,在网上查了下结合AJAX的应用,感觉应用前景还是不错的。为什么用这个组合呢?
1.NodeJS不需要安装,拷贝过去就可以使用,而环境变量可以只配置在当前cmd窗口,运行方便。
2.通过HTML的ajax请求,可以实现在不同的服务器上,可跨域获取数据。
3.通信数据格式灵活,可以是xml、json、binary等,数据适合任何平台。
在说说我的环境,我使用的是公司提供的电脑,有很多限制,比如是域中电脑,操作权限低,无法安装任何软件,无法修改计算机配置,无法使用U盘等等。所以我就自己配置了一个nodejs的绿色版环境,只能在当前cmd窗口运行nodejs的相关环境;无法架设html服务器,所以就单独在D盘创建一个html文件双击打开使用。
一、node环境就不说了,可以查看以下几篇文章
https://www.nhooo.com/article/33086.htm
https://www.nhooo.com/article/54678.htm
https://www.nhooo.com/article/57687.htm
二、编写node执行的脚本,脚本文件app.js如下:
varhttp=require("http");
varfs=require("fs");
varstr='{"id":"123",name:"jack",arg:11111}';
functiononRequest(request,response){
console.log("Requestreceived.");
response.writeHead(200,{"Content-Type":'text/plain','charset':'utf-8','Access-Control-Allow-Origin':'*','Access-Control-Allow-Methods':'PUT,POST,GET,DELETE,OPTIONS'});//可以解决跨域的请求
//response.writeHead(200,{"Content-Type":'application/json','Access-Control-Allow-Origin':'*','Access-Control-Allow-Methods':'PUT,POST,GET,DELETE,OPTIONS'});
//response.write("HelloWorld8888\n");
str=fs.readFileSync('data.txt');
response.write(str);
response.end();
}
http.createServer(onRequest).listen(8888);
console.log("Serverhasstarted.porton8888\n");
console.log("testdata:"+str.toString());
其中data.txt和当前app.js文件的放到相同的目录下,data.txt中代码是json格式的数据:{"id":"123",name:"jack",arg:321,remark:"testdata"}
通过nodeapp.js的方式运行起来,然后就可以让html通过ajax访问数据了。
另外就是我创建的html文件,文件aaa.html内容如下:
<!DOCTYPEhtml>
<html>
<head>
<title>NodeJS实例</title>
<scriptsrc="jquery-1.4.4.min.js"></script>
<script>
/*
//可用于检查出错函数的错误内容,一般使用$.get()和$.post()函数就可以了
$.ajax({
url:"http://127.0.0.1:8888/",
type:"GET",
dataType:"binary",//因为是调用nodeJS返回的json数据,所以必须使用binary类型
error:function(XMLHttpRequest,textStatus,errorThrown){
vars1=XMLHttpRequest;
vars2=textStatus;
vars3=errorThrown;
alert("errormessage:"+errorThrown.toString())
},
success:function(data){
$("#feeds").html(data);
vardataObj=eval('('+data+')');//转换为json对象
$("#id").html("编号:"+dataObj.id);
$("#name").html("姓名:"+dataObj.name);
$("#arg").html("年龄:"+dataObj.arg);
$("span").html(dataObj.remark);
//alert("Datais:"+data);
}
});
*/
//$.get("test.cgi",function(data){alert("DataLoaded:"+data);});//$.get函数形式结构
$.get("http://127.0.0.1:8888/"+newDate().getTime(),function(data){
$("#feeds").html(data);
vardataObj=eval('('+data+')');//转换为json对象
$("#id").html("编号:"+dataObj.id);
$("#name").html("姓名:"+dataObj.name);
$("#arg").html("年龄:"+dataObj.arg);
$("span").html(dataObj.remark);
//alert("DataLoaded:"+newDate().getTime());
});
</script>
</head>
<body>
<divid="feeds"></div>
<divid=id></div>
<divid=name></div>
<divid=arg></div>
<span>ddddd</span>
</body>
</html>
文件中都做了相应的注释说明,这里就不再解释了,其中用到的jquery的js文件自己去网上下载一个,也同样放到当前html文件的目录下。
有一点说明下:我下载了jquery的1.8.3版和2.1.4版都会报错,可能对json的支持不是很好,使用1.4.4版可正常运行,其他版本没有测试。
在我本机和内网测试正常显示如下:
{"id":"123",name:"jack",arg:32100,remark:"testdata"}
编号:123
姓名:jack
年龄:32100
testdata
以上环境都是本人亲自测试,希望对大家的学习有所帮助,也希望大家多多支持毛票票。