ホームページ > 記事 > ウェブフロントエンド > Jquery は、ajax 経由で NodeJS にリクエストして、JSON データ インスタンスを返します。
最近、インターネットで NodeJS について読み、AJAX と組み合わせたアプリケーションを確認しましたが、アプリケーションの見通しは非常に良いと感じています。なぜこの組み合わせを使用するのでしょうか?
1. NodeJS をインストールする必要はなく、コピーして使用するだけでよく、環境変数は現在の cmd ウィンドウでのみ設定できるため、実行が簡単です。
2. HTML ajax リクエストを通じて、異なるサーバー上のドメイン間でデータを取得できます。
3. 通信データ形式は柔軟で、xml、json、バイナリなど、あらゆるプラットフォームに適しています。
私の環境について話しましょう。私は会社から提供されたコンピューターを使用していますが、これはドメイン内のコンピューターであり、ソフトウェアをインストールしたり、コンピューターの構成を変更したりすることはできません。 、USBフラッシュドライブ等は使用できません。そこで、nodejs 環境のグリーン バージョンを自分で構成しました。これは、現在の cmd ウィンドウで nodejs 関連の環境のみを実行できます。HTML サーバーをセットアップできないため、D ドライブに別の HTML ファイルを作成し、それをダブルクリックしました。それを開くために。
ノード実行用のスクリプトを記述します。スクリプト ファイル 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 ファイルは同じディレクトリに配置されます。 json 形式のデータです:{"id":"123",name:"jack",arg:321,remark:"test data"}
ノード app.js を通じて実行すると、html がajaxを介したデータ。
もう 1 つは私が作成した 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>
ファイル内に対応するコメントがありますが、ここでは説明しません。それ自体はインターネットにアクセスしてダウンロードし、現在の html ファイルのディレクトリに置きます。
ちょっとした説明: jquery のバージョン 1.8.3 と 2.1.4 をダウンロードすると、json のサポートがあまり良くない可能性があり、他のバージョンは正常に動作しませんでした。テストされました。
私のローカルマシンとイントラネットテストでの通常の表示は次のとおりです:
{"id":"123",name:"jack",arg:32100, Reply:"test data"}
番号: 123
名前: jack
年齢: 32100歳
テストデータ
上記の環境は私自身がテストしたものであり、皆様の学習に役立つことを願っています