JavaScript 如何处理 php 返回json格式的数据

时间:2024.4.14

JavaScript 如何处理 php 返回json格式的数据

JavaScript 如何处理 php 返回json格式的数据,下面我们通过一个示例来说明!

假设php返回如下一个数组:

查看代码打印

01

$arr = array(

02

array(

03

'name'=>'qianyuqianxun',

04

'nick'=>'千与千寻',

05

'contact'=>array(

06

'website'=>''

07

)

08

),

09

array(

10

'name'=>'qisha',

11

'nick'=>'七煞',

12

'email'=>'yhm.1234@163.com',

13

'contact'=>array(

14

'website'=>''

15

)

16

)

17

);

18

print_r(json_encode($arr));

19

exit;

则客户端JS可如下调用以上返回的数据:

查看代码打印

01

$(document).ready(function(){

02

var url='/json.php'

03

$('#submitBtn').click(function(){

04

$.post(url,'',function(msg){

05

var myObject=eval('('+msg+')');//msg为返回的类型为字符串,转化为json对象 06

var str='';

07

var len=myObject.length;

08

for(i=0;i<len;i++){

09

str+='<tr><td>'+myObject[i].name+'</td><td>'+myObject[i].nick+'</td><td>'+myObject[i].contact.website+'</td></tr>';

10

}

11

$('#feedbackTable').html(str);

12

})

13

})

14

})


第二篇:JavaScript操作Json


JSON (JavaScript Object Notation)一种简单的数据格式,比xml更轻巧。 JSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不需要任何特殊的 API 或工具包。

JSON的规则很简单: 对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“,”(逗号)分隔。具体细节参考

举个简单的例子:

js 代码 1.

2.

3.

4.

5.

6. 7.

8.

9. function showJSON() { var user = { "username":"andy", "age":20, "info": { "tel": "123456", "cellphone": "98765"}, "address": [ {"city":"beijing","postcode":"222333"},

10. {"city":"newyork","postcode":"555666"}

11. ]

12. }

13.

14. alert(user.username);

15. alert(user.age);

16. alert(user.info.cellphone);

17. alert(user.address[0].city);

18. alert(user.address[0].postcode);

19. }

这表示一个user对象,拥有username, age, info, address 等属性。 同样也可以用JSON来简单的修改数据,修改上面的例子

js 代码

1.

2. function showJSON() { var user =

3.

4.

5.

6.

7.

8.

9. { "username":"andy", "age":20, "info": { "tel": "123456", "cellphone": "98765"}, "address": [ {"city":"beijing","postcode":"222333"},

10. {"city":"newyork","postcode":"555666"}

11. ]

12. }

13.

14. alert(user.username);

15. alert(user.age);

16. alert(user.info.cellphone);

17. alert(user.address[0].city);

18. alert(user.address[0].postcode);

19.

20. user.username = "Tom";

21. alert(user.username);

22. }

JSON提供了json.js包,下载 后,将其引入然后就可以简单的使用object.toJSONString()转换成JSON数据。

js 代码

1.

2.

3.

4.

5.

6.

7.

8.

9. function showCar() { var carr = new Car("Dodge", "Coronet R/T", 1968, "yellow"); alert(carr.toJSONString()); } function Car(make, model, year, color) { this.make = make; this.model = model; this.year = year;

10. this.color = color;

11. }

可以使用eval来转换JSON字符到Object

js 代码 1.

2.

3.

4.

5. function myEval() { var str = '{ "name": "Violet", "occupation": "character" }'; var obj = eval('(' + str + ')'); alert(obj.toJSONString()); }

或者使用parseJSON()方法

js 代码 1.

2.

3.

4.

5. function myEval() { var str = '{ "name": "Violet", "occupation": "character" }'; var obj = str.parseJSON(); alert(obj.toJSONString()); }

下面使用prototype写一个JSON的ajax例子。

先写一个servlet (我的是servlet.ajax.JSONTest1.java)就写一句话 java 代码

1. response.getWriter().print("{ /"name/": /"Violet/", /"occupation/": /"character/" }");

再在页面中写一个ajax的请求

js 代码 1.

2.

3.

4.

5.

6.

7.

8.

9. function sendRequest() { var url = "/MyWebApp/JSONTest1"; var mailAjax = new Ajax.Request( url, { method: 'get', onComplete: jsonResponse } );

10. }

11.

12. function jsonResponse(originalRequest) {

13. alert(originalRequest.responseText);

14. var myobj = originalRequest.responseText.parseJSON();

15. alert(myobj.name);

16. }

prototype-1.5.1.js中提供了JSON的方法,String.evalJSON(), 可以不使用json.js, 修改上面的方法

js 代码

1.

2.

3.

4. 5. function jsonResponse(originalRequest) { alert(originalRequest.responseText); var myobj = originalRequest.responseText.evalJSON(true); alert(myobj.name); }

JSON还提供了java的jar包 API也很简单,下面举个例子

在javascript中填加请求参数

js 代码 1.

2.

3.

4.

5.

6.

7.

8.

9. function sendRequest() { var carr = new Car("Dodge", "Coronet R/T", 1968, "yellow"); var pars = "car=" + carr.toJSONString(); var url = "/MyWebApp/JSONTest1"; var mailAjax = new Ajax.Request( url, { method: 'get',

10. parameters: pars,

11. onComplete: jsonResponse

12. }

13. );

14. } 使用JSON请求字符串就可以简单的生成JSONObject并进行解析,修改servlet添加JSON的处理(要使用json.jar)

java 代码 1. private void doService(HttpServletRequest request, HttpServletR

esponse response) throws IOException {

String s3 = request.getParameter("car"); try {

JSONObject jsonObj = new JSONObject(s3);

System.out.println(jsonObj.getString("model"));

System.out.println(jsonObj.getInt("year"));

} catch (JSONException e) {

e.printStackTrace();

}

/": /"character/" }"); 2. 3. 4. 5. 6. 7. 8. 9. 10. response.getWriter().print("{ /"name/": /"Violet/", /"occupation

11. }

同样可以使用JSONObject生成JSON字符串,修改servlet

java 代码 1. private void doService(HttpServletRequest request, HttpServletResponse resp

onse) throws IOException {

2. String s3 = request.getParameter("car");

3. try {

4. JSONObject jsonObj = new JSONObject(s3);

5. System.out.println(jsonObj.getString("model"));

6. System.out.println(jsonObj.getInt("year"));

7. } catch (JSONException e) {

8. e.printStackTrace();

9. }

10.

11. JSONObject resultJSON = new JSONObject();

12. try {

13. resultJSON.append("name", "Violet") 14. .append("occupation", "developer")

15. .append("age", new Integer(22));

16. System.out.println(resultJSON.toString());

17. } catch (JSONException e) {

18. e.printStackTrace();

19. }

20. response.getWriter().print(resultJSON.toString());

21. }

js 代码

1. function jsonResponse(originalRequest) {

2. alert(originalRequest.responseText);

3. var myobj = originalRequest.responseText.evalJSON(true);

4. alert(myobj.name);

5. alert(myobj.age);

6. }

更多相关推荐:
怎样写好research proposal(中文)

大多数学生和刚起步的研究者都不了解什么是研究计划也不知道其重要性简单的说一个人研究计划的好坏决定了其研究的好坏一个构思欠佳的研究计划会毁了整个项目即使它勉强通过了论文答辩委员会另一方面一个高质量的研究计划不仅确...

research proposal范文

Researchproposal1TitleCormacMcCarthysTheRoadandAmericanModernEschatologyOrModernEschatologyofthe21stcentu...

research proposal

DevelopingResearchProposalsHandoutPreparedbyTedZornUniversityofWaikatoThisisahandoutIoftengivetostudentswhenIexpect...

申请文书Research proposal怎么写

申请文书Researchproposal怎么写首先先讨论最常见的SOP无论申请什么学校一定都会要求SOP这份文件通常分以下几个部份大学时期修过课程大学时期研究硕班时期修过课程硕班时期研究课外活动打工或经验毕业后...

怎样写好research proposal

每个学术研究者必须经历的一道关卡就是ResearchProposal的写作它大致对应中文里的开题报告选题报告研究报告是一项研究开始之前的提纲规划和陈述既是为了帮助自己梳理文献整理思路廓清方向也常常是写给相关他人...

怎样写一篇好的research proposal

怎样写一篇好的researchproposal每个学术研究者必须经历的一道关卡就是ResearchProposal的写作它大致对应中文里的开题报告选题报告研究报告是一项研究开始之前的提纲规划和陈述既是为了帮助自...

Research-Proposal-写作格式-20xx (1)

ResearchProposalBandIII20xxResearchProposalSchoolofForeignLanguages20xx031ResearchProposalBandIII20xx2ResearchPropo...

format of a research paper introduction论文的标准格式

WritingaResearchPaperIntroductionAstepbystepreferenceTheintroductionisthefirstchapterofaItstartsfromtheresearchprop...

Paper Proposal0

PaperProposalEngineeringIntroductiontomechanicalEngineeringTABLEOFCONTENTSEXECUTIVESUMMARY错误未定义书签12INTROD...

提案报告写作Report and Technical Writing-Proposal

ReportandTechnicalWritingProposalsICheckingtheExercisesofAnalyticalReports1Whatarethemajordifferencesbetweeninforma...

论文架构 Research Paper

论文架构ResearchPaper1选题2查阅资料将选题具体化3收集资料并整理作笔记或卡片4开题报告5撰写任务书6提纲起草论文文献综述毕业论文文献综述文献综述要写明目的范围研究现状以及作者的评价和自己的观点一篇...

position paper-中文范文

代表学校国家委员会议题金融危机中的国际合作自20xx年9月以来由美国次贷危机所引发的金融经济危机已经波及全球在此期间如华尔街五大投资公司的彻底消失股市期货的一路贬值各国经济指标的自由落体式的下滑都不约而同地一再...

research proposal (30篇)