zoukankan      html  css  js  c++  java
  • 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
    ");
      
      str=fs.readFileSync('data.txt');
      response.write(str);
      response.end();
    }
    
    http.createServer(onRequest).listen(8888);
    
    console.log("Server has started.port on 8888
    ");
    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

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

  • 相关阅读:
    &和&&的区别
    AOP和IOC的实现原理(用到的设计模式)
    字符串里有数字和字符,如何只获取一种(以数字为例)
    maven的搭建
    java中递归的方法的实例
    从零开始学习oracle
    各个浏览器的webdriver
    “equals”有值 与 “==”存在 “equals”只是比较值是否相同,值传递,==地址传递,null==a,避免引发空指针异常,STRING是一个对象==null,对象不存在,str.equals("")对象存在但是包含字符‘''
    Oracle基础入门
    orcale => 含义
  • 原文地址:https://www.cnblogs.com/mq0036/p/5261784.html
Copyright © 2011-2022 走看看