亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

PHP開(kāi)發(fā)實(shí)作下載次數(shù)統(tǒng)計(jì)功能模組(三)

jQuery主要完成兩個(gè)任務(wù),一是透過(guò)Ajax非同步讀取檔案清單並展示,二是回應(yīng)使用者點(diǎn)擊事件,將對(duì)應(yīng)的檔案下載次數(shù)+1。

首先,頁(yè)面載入完後,透過(guò)$.ajax()向後臺(tái)filelist.php發(fā)送GET形式的Ajax請(qǐng)求,當(dāng)filelist.php相應(yīng)成功後,接收返回的json數(shù)據(jù),透過(guò)$. each()遍歷json資料對(duì)象,建構(gòu)html字串,並將最終得到的字串加入ul.filelist中,形成了demo中的檔案清單。

然後,點(diǎn)擊檔案下載時(shí),透過(guò)live()回應(yīng)動(dòng)態(tài)加入的清單元素的click事件,將下載次數(shù)進(jìn)行累加。

<script type="text/javascript">
$(function(){
   $.ajax({  //異步請(qǐng)求
      type: 'GET',
      url: 'filelist.php',
      dataType: 'json',
      cache: false,
      beforeSend: function(){
         $(".filelist").html("<li class='load'>正在載入...</li>");
      },
      success: function(json){
         if(json){
            var li = '';
            $.each(json,function(index,array){
               li = li + '<li><a href="download.php?id='+array['id']+'">'+array['file']+'<span class="downcount" title="下載次數(shù)">'
               +array['downloads']+'</span><span class="download">點(diǎn)擊下載</span></a></li>';
              });
            $(".filelist").html(li);
         }
      }
   });
   $('ul.filelist a').live('click',function(){
      var count = $('.downcount',this);
      count.text(parseInt(count.text())+1);
   });
});
</script>

註解

#ajax中的各種參數(shù)

1.type

##類(lèi)型: String

預(yù)設(shè)值: "GET")。請(qǐng)求方式 ("POST" 或 "GET"), 預(yù)設(shè)為 "GET"。

2.url

類(lèi)型:String

預(yù)設(shè)值: 目前頁(yè)位址。發(fā)送請(qǐng)求的位址。

3.dataType

類(lèi)型:String

#預(yù)期伺服器傳回的資料類(lèi)型。這裡為"json": 傳回 JSON 資料 。

4.cache

類(lèi)型:Boolean

預(yù)設(shè)值: true,dataType 為 script 和 jsonp 時(shí)預(yù)設(shè)為 false。設(shè)定為 false 將不快取此頁(yè)面。

5.beforeSend

類(lèi)型:Function

發(fā)送請(qǐng)求前可修改 XMLHttpRequest 物件的函數(shù)。

XMLHttpRequest 物件是唯一的參數(shù)。

6.success

類(lèi)型:Function

請(qǐng)求成功後的回呼函數(shù)。

live() 方法為被選元素附加一個(gè)或多個(gè)事件處理程序,並規(guī)定當(dāng)這些事件發(fā)生時(shí)執(zhí)行的函數(shù)。

最後,其實(shí)通讀本文,這就是一個(gè)我們通常應(yīng)用到的Ajax案例,當(dāng)然還有PHP結(jié)合mysql實(shí)現(xiàn)下載的知識(shí),希望對(duì)大家有幫助

如果想學(xué)習(xí)更多jQuery,ajax知識(shí),請(qǐng)參考我們ipnx.cn的相關(guān)教學(xué)。

繼續(xù)學(xué)習(xí)
||
<script type="text/javascript"> $(function(){ $.ajax({ //異步請(qǐng)求 type: 'GET', url: 'filelist.php', dataType: 'json', cache: false, beforeSend: function(){ $(".filelist").html("<li class='load'>正在載入...</li>"); }, success: function(json){ if(json){ var li = ''; $.each(json,function(index,array){ li = li + '<li><a href="download.php?id='+array['id']+'">'+array['file']+'<span class="downcount" title="下載次數(shù)">' +array['downloads']+'</span><span class="download">點(diǎn)擊下載</span></a></li>'; }); $(".filelist").html(li); } } }); $('ul.filelist a').live('click',function(){ var count = $('.downcount',this); count.text( parseInt(count.text())+1); }); }); </script>
提交重置程式碼