jQuery技术

Jquery通过ajax请求NodeJS返回json数据实例

字号+ 作者:H5之家 来源:H5之家 2016-11-26 14:37 我要评论( )

本文将为关注织梦者的朋友提供的是的Jquery通过ajax请求NodeJS返回json数据实例相关教程,具体实例代码请看下文:最近看了NodeJS相关的,在网上查了下结合AJAX的

本文将为关注织梦者的朋友提供的是的Jquery通过ajax请求NodeJS返回json数据实例相关教程,具体实例代码请看下文:

最近看了NodeJS相关的,在网上查了下结合AJAX的应用,感觉应用前景还是不错的。为什么用这个组合呢?

1.NodeJS不需要安装,拷贝过去就可以使用,而环境变量可以只配置在当前cmd窗口,运行方便。

2.通过HTML的ajax请求,可以实现在不同的服务器上,可跨域获取数据。

3.通信数据格式灵活,可以是xml、json、binary等,数据适合任何平台。

在说说我的环境,我使用的是公司提供的电脑,有很多限制,比如是域中电脑,操作权限低,无法安装任何软件,无法修改计算机配置,无法使用U盘等等。所以我就自己配置了一个nodejs的绿色版环境,只能在当前cmd窗口运行nodejs的相关环境;无法架设html服务器,所以就单独在D盘创建一个html文件双击打开使用。

一、node环境就不说了,可以查看以下几篇文章

二、编写node执行的脚本,脚本文件app.js如下:

var http = require("http"); var fs = require("fs"); var str='{"id":"123",name:"jack",arg:11111}'; function onRequest(request, response){ console.log("Request received."); 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("Hello World 8888\n"); str=fs.readFileSync('data.txt'); response.write(str); response.end(); } http.createServer(onRequest).listen(8888); console.log("Server has started.port on 8888\n"); console.log("test data: "+str.toString());

其中data.txt和当前app.js文件的放到相同的目录下,data.txt中代码是json格式的数据:{"id":"123",name:"jack",arg:321,remark:"test data"}

通过node app.js的方式运行起来,然后就可以让html通过ajax访问数据了。

另外就是我创建的html文件,文件aaa.html内容如下:

<!DOCTYPE html> <html> <head> <title>Node JS 实例</title> <script src="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){ var s1=XMLHttpRequest; var s2=textStatus; var s3=errorThrown; alert("error message : "+errorThrown.toString()) }, success: function(data){ $("#feeds").html(data); var dataObj=eval('('+data+')');//转换为json对象 $("#id").html("编号:"+dataObj.id); $("#name").html("姓名:"+dataObj.name); $("#arg").html("年龄:"+dataObj.arg); $("span").html(dataObj.remark); // alert( "Data is : " + data ); } }); */ //$.get("test.cgi", function(data){ alert("Data Loaded: " + data); }); //$.get函数形式结构 $.get("http://127.0.0.1:8888/" + new Date().getTime(), function(data){ $("#feeds").html(data); var dataObj=eval('('+data+')');//转换为json对象 $("#id").html("编号:"+dataObj.id); $("#name").html("姓名:"+dataObj.name); $("#arg").html("年龄:"+dataObj.arg); $("span").html(dataObj.remark); //alert("Data Loaded: "+new Date().getTime()); }); </script> </head> <body> <div></div> <div id=id></div> <div id=name></div> <div id=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:"test data"} 编号:123 姓名:jack 年龄:32100 test data

以上环境都是本人亲自测试,希望对大家的学习有所帮助,也希望大家多多支持织梦者。

这些内容可能对你也有帮助

更多可查看Javascript教程列表页。

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • JQuery技巧总结(转载)

    JQuery技巧总结(转载)

    2016-11-13 10:01

  • Struts 2.1.6精简实例系列教程(6):重写用户登录模块(整合Jquery+JSON)

    Struts 2.1.6精简实例系列教程(6):重写用户登录模块(整合Jquery+JS

    2016-11-12 18:02

  • JQuery使用实例学习

    JQuery使用实例学习

    2016-10-17 11:02

  • jQuery实现AJAX插件

    jQuery实现AJAX插件

    2016-09-21 13:00

网友点评