一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - PHP教程 - PHP+ajax實(shí)現(xiàn)獲取新聞數(shù)據(jù)簡(jiǎn)單示例

PHP+ajax實(shí)現(xiàn)獲取新聞數(shù)據(jù)簡(jiǎn)單示例

2019-10-09 15:03ll_xiaohanqing_91 PHP教程

這篇文章主要介紹了PHP+ajax實(shí)現(xiàn)獲取新聞數(shù)據(jù),涉及php ajax交互獲取信息及json格式處理的相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了PHP+ajax實(shí)現(xiàn)獲取新聞數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:

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

① 可以借助JSON對(duì)象的方法stringify()parse()方法,進(jìn)行字符串和對(duì)象之間的轉(zhuǎn)換

var arr=[1,2,3];
var a={left:100};
//alert(JSON.stringify(a));//typeof JSON.stringify(arr)是string
//JSON對(duì)象的輸出有嚴(yán)格格式:'{"left":100}',變量值要加雙引號(hào)
var s1="[1,2,3]";
var s2="{left:100}";
var s3='{"left":100}';
//alert(JSON.parse(s1));//---輸出數(shù)組[1,2,3]
//alert(JSON.parse(s2));//---出錯(cuò)。因?yàn)镴SON對(duì)象格式嚴(yán)格,必須是:'{"left":100}'的格式
alert(JSON.parse(s3).left);//---輸出Object Object

②ajax獲取服務(wù)器內(nèi)容的實(shí)例:

getNews.php代碼:

<?php
header('content-type:text/html;charset="utf-8"');
error_reporting(0);
$news=array(
  array("title"=>'習(xí)近平同代表委員共商國是兩會(huì)細(xì)節(jié) 國平',"date"=>"2016-3-16"),
   array("title"=>'李克強(qiáng)答如何解決"工資8000元到手僅5000元"',"date"=>"2016-3-16"),
   array("title"=>'兩會(huì)閉幕遼寧"老虎"落馬曾3年3連跳升副部級(jí)',"date"=>"2016-3-16"),
   array("title"=>'寧波市長(zhǎng)盧子躍嚴(yán)重違紀(jì)被查 被指行賄斯鑫良',"date"=>"2016-3-16"),
   array("title"=>'美女翻譯六上總理記者會(huì) 外號(hào)櫻桃小丸子',"date"=>"2016-3-16"),
   array("title"=>'外媒:印尼警方擊斃兩名中國籍極端分子',"date"=>"2016-3-16"),
   array("title"=>'復(fù)旦將抗腫瘤藥物專利6500萬美元售美國公司',"date"=>"2016-3-16"),
 );
echo json_encode($news);

文件getNews.php在瀏覽器中顯示為:

復(fù)制代碼代碼如下:
[{"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"}]

 

返回一個(gè)數(shù)組,數(shù)組元素為7個(gè)JSON對(duì)象,每個(gè)對(duì)象有兩個(gè)屬性:title和date

前端需要做的是,得到這些數(shù)據(jù),并把它們通過DOM操作放在網(wǎng)頁的相應(yīng)位置上。

Ajax:通過某個(gè)接口(文件)去服務(wù)器取數(shù)據(jù),把取回來的數(shù)據(jù),根據(jù)數(shù)據(jù)特性,放在客戶端網(wǎng)頁上處理。

<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-www-form-urlencoded");
xhr.send();
xhr.onreadystatechange=function(){
if(xhr.readyState==4){
  if(xhr.status==200){
    var data=JSON.parse(xhr.responseText);
    varoUl=document.getElementById("ul1");
    var html=''; //DOM操作,把服務(wù)器取回的內(nèi)容顯示在網(wǎng)頁上。
    for(var i=0; i<data.length;i++) {
     html+='<li> <a herf="">'+ data[i].title + '</a> [<span>' + data[i].date + '</span>]</li>';
   }
    oUl.innerHTML=html;
    }else{
     alert("出錯(cuò)了,Err: " + xhr.status);
    }
  }
}

取回?cái)?shù)據(jù)的頁面:

PHP+ajax實(shí)現(xiàn)獲取新聞數(shù)據(jù)簡(jiǎn)單示例

③ajax函數(shù)簡(jiǎn)單封裝

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-www-form-urlencoded")        xhr.send(data);
}
xhr.onreadystatechange=function(){
  if(xhr.readyState==4){
      if(xhr.status==200){
        fn(xhr.responseText);
      }else{
        alert("出錯(cuò)了,Err: " + xhr.status);
      }
    }
  }
}

④ajax輪詢方式獲取服務(wù)器資源

setInterval(function(){
   ajax('get','getNews.php','',function(data){
      var data=JSON.parse(data);//參數(shù)回調(diào)
      var oUl=document.getElementById("ul1");
      var html='';
      for (var i=0; i<data.length;i++){
        html+='<li> <aherf="">' + data[i].title + '</a> [<span>' +data[i].date + '</span>] </li>';
      }
      oUl.innerHTML=html;
    });
},1000);//ajax輪詢方式,1秒鐘自動(dòng)更新一次頁面。
    //ajax真正的輪詢不會(huì)1s鐘一次那么快,這樣太耗資源。

 

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品国产一区二区三区久久久蜜臀 | 青青草亚洲| 日本高清免费不卡在线播放 | a级毛片毛片免费观看永久 a级黄色片免费 | 免费欧美一级片 | 国内自拍网红在线综合 | 四虎影视色费永久在线观看 | 国产精品免费_区二区三区观看 | 四虎网站网址 | 大陆黄色片 | 国产亚洲精品综合在线网址 | 青青青青青国产免费手机看视频 | 免费亚洲视频 | 女子校生下媚药在线观看 | 免费操比视频 | 成人福利 | 国产在线精品成人一区二区三区 | 韩剧在线观看 | s0e一923春菜花在线播放 | 精品国产成人 | 卫生间被教官做好爽HH视频 | 国产精品反差婊在线观看 | 五月天精品视频在线观看 | 九九热在线观看视频 | 男女激情网 | 久久视频精品3线视频在线观看 | 91久久青青青国产免费 | 欧美日韩精品免费一区二区三区 | 天天操天天干天天做 | 欧美高清在线精品一区 | 成人免费草草视频 | 95视频免费看片 | 草莓丝瓜芭乐樱桃榴莲色多黄 | 俄罗斯激情性孕妇孕交大全 | 免费aⅴ在线 | 香蕉精品视频 | 操老逼| 国产黄频在线观看高清免费 | 8x8x丝袜美女| 欧美大片一级片 | 欧美日本一本线在线观看 |