Jquery는 ajax를 통해 NodeJS에 json 데이터 인스턴스를 반환하도록 요청합니다.

高洛峰
풀어 주다: 2016-12-07 14:12:04
원래의
1319명이 탐색했습니다.

최근 NodeJS에 대해 읽고 인터넷에서 AJAX와 결합된 애플리케이션을 확인해 보니 애플리케이션 전망이 꽤 좋다고 느꼈습니다. 이 조합을 사용하는 이유는 무엇입니까?

1. NodeJS는 설치가 필요 없으며, 그냥 복사해서 사용하면 됩니다. 현재 cmd 창에서만 환경변수를 설정할 수 있어 실행이 쉽습니다.

2. HTML ajax 요청을 통해 서로 다른 서버의 서로 다른 도메인에서 데이터를 얻을 수 있습니다.

3. 통신 데이터 형식은 유연하며 xml, json, 바이너리 등이 될 수 있습니다. 데이터는 모든 플랫폼에 적합합니다.

회사에서 제공하는 컴퓨터를 사용하고 있는데, 예를 들어 도메인에 속한 컴퓨터이고 어떤 소프트웨어도 설치할 수 없습니다. 컴퓨터 구성을 수정할 수 없으며 USB 플래시 드라이브 등을 사용할 수 없습니다. 그래서 현재 cmd 창에서는 nodejs 관련 환경만 실행할 수 있는 그린 버전의 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 파일은 동일한 디렉터리에 있습니다. 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(&#39;(&#39;+data+&#39;)&#39;);//转换为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(&#39;(&#39;+data+&#39;)&#39;);//转换为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를 다운로드했는데 둘 다 오류가 보고되었습니다. 버전 1.4.4는 정상적으로 실행되지 않을 수 있습니다. 테스트되었습니다.

내 로컬 컴퓨터 및 인트라넷 테스트의 일반적인 표시는 다음과 같습니다.

{"id":"123",name:"jack",arg:32100, comment:"test data "}
번호: 123
이름: jack
나이: 32100
테스트 데이터

위 환경은 제가 직접 테스트한 환경입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. PHP 중국어 넷을 지원해주세요


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿