PHP+ajax实现获取新闻数据简单示例

2018-09-07 14:23

阅读:182

  本文实例讲述了PHP+ajax实现获取新闻数据的方法。分享给大家供大家参考,具体如下:

  Get方式获取到的信息是字符串(responseText)

  ① 可以借助JSON对象的方法:stringify()和parse()方法,进行字符串和对象之间的转换

   var arr=[1,2,3]; var a={left:100}; //alert(JSON.stringify(a));//typeof JSON.stringify(arr)是string //JSON对象的输出有严格格式:{left:100},变量值要加双引号 var s1=[1,2,3]; var s2={left:100}; var s3={left:100}; //alert(JSON.parse(s1));//---输出数组[1,2,3] //alert(JSON.parse(s2));//---出错。因为JSON对象格式严格,必须是:{left:100}的格式 alert(JSON.parse(s3).left);//---输出Object Object

  ②ajax获取服务器内容的实例:

  getNews.php代码:

   <?php header(content-type:text/html;charset=utf-8); error_reporting(0); $news=array( array(title=>习同代表委员共商国是两会细节 国平,date=>2016-3-16), array(title=>李克强答如何解决工资8000元到手仅5000元,date=>2016-3-16), array(title=>两会闭幕辽宁老虎落马曾3年3连跳升副部级,date=>2016-3-16), array(title=>宁波市长卢子跃严重违纪被查 被指行贿,date=>2016-3-16), array(title=>美女翻译六上总理记者会 外号樱桃小丸子,date=>2016-3-16), array(title=>外媒:印尼警方击毙两名中国籍极端分子,date=>2016-3-16), array(title=>复旦将抗肿瘤药物专利6500万美元售美国公司,date=>2016-3-16), ); echo json_encode($news);

  文件getNews.php在浏览器中显示为:
复制代码 代码如下:[{title:\u4e60\u8fd1\u5e73\u540c\u4ee3\u8868\u59d4\u5458\u5171\u5546\u56fd\u662f\u4e24\u4f1a\u7ec6\u8282 \u56fd\u5e73,date:2016-3-16},<span style=font-family: Arial, Helvetica, sans-serif;>{title:\u674e\u514b\u5f3a\u7b54\u5982\u4f55\u89e3\u51b3\\u5de5\u8d448000\u5143\u5230\u624b\u4ec55000\u5143\,date:2016-3-16},</span><span style=font-family: Arial, Helvetica, sans-serif;>{title:\u4e24\u4f1a\u95ed\u5e55\u8fbd\u5b81\\u8001\u864e\\u843d\u9a6c\u66fe3\u5e743\u8fde\u8df3\u5347\u526f\u90e8\u7ea7,date:2016-3-16},{title:\u5b81\u6ce2\u5e02\u957f\u5362\u5b50\u8dc3\u4e25\u91cd\u8fdd\u7eaa\u88ab\u67e5\u88ab\u6307\u884c\u8d3f\u65af\u946b\u826f,date:2016-3-16},{title:\u7f8e\u5973\u7ffb\u8bd1\u516d\u4e0a\u603b\u7406\u8bb0\u8005\u4f1a\u5916\u53f7\u6a31\u6843\u5c0f\u4e38\u5b50,date:2016-3-16},{title:\u5916\u5a92:\u5370\u5c3c\u8b66\u65b9\u51fb\u6bd9\u4e24\u540d\u4e2d\u56fd\u7c4d\u6781\u7aef\u5206\u5b50,date:2016-3-16},{title:\u590d\u65e6\u5c06\u6297\u80bf\u7624\u836f\u7269\u4e13\u52296500\u4e07\u7f8e\u5143\u552e\u7f8e\u56fd\u516c\u53f8,date:2016-3-16}]

  返回一个数组,数组元素为7个JSON对象,每个对象有两个属性:title和date

  前端需要做的是,得到这些数据,并把它们通过DOM操作放在网页的相应位置上。

  Ajax:通过某个接口(文件)去服务器取数据,把取回来的数据,根据数据特性,放在客户端网页上处理。

   <body> <input id=btn type=button value=按钮/> <ul id=ul1>获取新闻到该处</ul> <script src=JSON.js></script> <script src=ajax.js></script> </body> xhr.open(get,getNews.php,true); xhr.setRequestHeader(content-type,application/x-操作,把服务器取回的内容显示在网页上。erHTML=html; }else{ alert(出错了,Err: + xhr.status); } } }

  取回数据的页面:

  ③ajax函数简单封装

   functionajax(method,url,data,fn){ try{ xhr=new XMLHttpRequest(); }catch(e){ xhr=newActiveXObject(Microsoft.XMLHTTP); } if(method == get &&data){ url+=?+data; } xhr.open(method,url,true); if(method==get){ xhr.send(); }else{ xhr.setRequestHeader(content-type,application/x-出错了,Err: + xhr.status); } } } }

  ④ajax轮询方式获取服务器资源

   setInterval(function(){ ajax(get,getNews.php,,function(data){ var data=JSON.parse(data);//参数回调erHTML=html; }); },1000);//ajax轮询方式,1秒钟自动更新一次页面。 //ajax真正的轮询不会1s钟一次那么快,这样太耗资源。

  更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP+ajax技巧与应用小结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

  希望本文所述对大家PHP程序设计有所帮助。


评论


亲,登录后才可以留言!