最近看了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 id="feeds"></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

以上环境都是本人亲自测试,如有转载请注明出处。

Jquery通过ajax请求NodeJS返回json数据相关推荐

  1. java中使用ajax请求数据格式化,ajax请求服务器返回json数据格式化

    JQuery--实现Ajax应用 实现Ajax应用 1   .load()异步请求数据,通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,调用格式为load(url,[data], ...

  2. ajax请求Struts2返回JSON数据方法

    如果是作为客户端的HTTP+JSON接口工程,没有JSP等view视图的情况下,使用Jersery框架开发绝对是第一选择.而在基于Spring3 MVC的架构下,对HTTP+JSON的返回类型也有很好 ...

  3. 使用Struts接受Ajax请求并且返回Json数据

    本质 本质上Struts2接受Ajax请求和SpringMVC差不多,因为ajax请求的发起都是由页面来完成的,在MVC的C层只需要接受参数,然后使用Json相关的工具类封装成Json对象返回就行了 ...

  4. jquery的ajax异步请求接收返回json数据

    jquery的ajax异步请求接收返回json数据方法设置简单,一个是服务器处理程序是返回json数据,另一种就是ajax发送设置的datatype设置为jsonp格式数据或json格式都可以.这篇文 ...

  5. ajax使用json下拉框,ajax请求后台得到json数据后动态生成树形下拉框的方法

    如下所示: $(function(){ $.ajax({ url:"departmentAction_getAllDep.action", type:"post" ...

  6. ajax请求返回的数据格式,ajax请求服务器返回json数据格式

    ajax请求服务器返回json数据格式 内容精选 换一换 消息请求返回的状态码如下表所示. 使用API数据源,您可以通过调用一个第三方的REST(Representational State Tran ...

  7. SpringMVC接收ajax请求并回传json数据,配置的步骤及问题解决。No converter found for type ArrayList with Content-Type null

    1. 在maven项目的pom.xml文件引入依赖 <dependency><groupId>com.fasterxml.jackson.core</groupId> ...

  8. 使用JSONP,jQuery的ajax跨域获取json数据

    网上找了很多资料,写的不错,推荐下: 1.深入浅出JSONP--解决ajax跨域问题 (http://www.cnblogs.com/chopper/archive/2012/03/24/240394 ...

  9. ajax请求php返回的数据是整个页面的html,Ajax出错并返回整个页面html的问题

    有这样一个例子在thinkPHP视图页面执行一个给评论点赞的功能,为了强化用户体验,一般都采用ajax异步请求后台处理点赞数据,成功后页面执行局部更新后的数据即可.前台通常会用到jquery,通过执行 ...

最新文章

  1. CString工作原理和常见问题分析
  2. 滴答定时器的计数模式_SysTick(系统滴答定时器)
  3. 不需要人际交往的计算机系,计算机对大学生人际交往影响.doc
  4. linux命令history作用,Linux命令:history命令历史的管理及用法
  5. 【深入浅出etcd系列】4. 客户端
  6. 元宵节正月十五素材图片,可以做壁纸高清!
  7. python绘制复杂表格_Python3绘制整齐的表格
  8. python基础代码大全-Python字典及基本操作(超级详细)
  9. Q108:浅析PBRT-V3的代码结构
  10. 用iostat对linux硬盘IO性能进行检测
  11. 距离之和最小 V3 51Nod - 1110(带权中位数或者爆搜)
  12. 【简单快速】启动后桌面正常下方任务栏无反应/鼠标一直转圈
  13. C# 项目实战(经典)
  14. 小程序微信官方推荐登录流程设计
  15. centos7 默认中文字体_centos7安装中文宋体
  16. ftp服务器在线编辑,ftp服务器上怎么直接修改office文档.
  17. 选第二大算法(锦标赛算法)
  18. 微信小程序 - 基本原理
  19. LANDESK DM桌面管理之客户端配置及部署篇
  20. AcWing 2041. 干草堆

热门文章

  1. 性能优化技巧 - 组表数据更新
  2. 1 2 5组合100,有多少种方法
  3. 「欧洲AI联合实验室」ELLIS成立:誓与中美抢人才
  4. DBA巡检常用的SQL语句
  5. cocos2d-x学习笔记(十)android自动化打包bat脚本
  6. WEB中会话跟踪[转]
  7. struts2配置的ajax参数传递方法
  8. UITextField与UITextView的区别
  9. 转载:thread的六种状态
  10. Fragment详解之五——Fragment间参数传递