2012-04-12 98 views
0

在下面的代碼我想在某種程度上增加一個Ajax調用,每次,畢竟圖像有Ajax調用來獲取新的數據

被證明,阿賈克斯將觸發我的PHP尋找到了/圖片查看是否有新文件。

如果有任何新文件,應在下一個循環中添加並顯示它們。

<html> 
<meta http-equiv="refresh" content="1000"/> 
<head> 
<title>Slideshow</title> 
<style type="text/css"> 
    #slideshow 
    #slideshow img { padding: 15px; border: 1px solid #ccc; background-color: #eee; } 
    #slide {width: 370px; height: 220px; padding: 0; margin: 0 auto; } 

    #myslides { 
    width: 370px; 
    height: 220px; 
    padding: 0; 
    margin: 0 auto; 
} 

#myslides img { 
    padding: 10px; 
    border: 1px solid rgb(100,100,100); 
    background-color: rgb(230,230,230); 
    width: 350px; 
    height: 200px; 
    top: 0; 
    left: 0 
} 

</style> 
</head> 
<!-- include jQuery library --> 

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script> 

<!-- include Cycle plugin --> 
<script type="text/javascript" src="http://cloud.github.com/downloads/malsup/cycle/jquery.cycle.all.latest.js"></script> 

<script type="text/javascript"> 
$(document).ready(function(){ 
$('#slideshow').cycle({ 
       fx: 'fade', 
       speed: 700, 
       timeout: 8000 
     }); 
}); 
</script> 

<body> 

<div id="slideshow"> 

<?php 

    function returnimages($dirname="./images") { 
     $pattern="([^\s]+(\.(?i)(jpg|png|gif|bmp))$)";  
     $files = array(); 
     if($handle = opendir($dirname)) { 
      while(false !== ($file = readdir($handle))){ 
       if(preg_match($pattern, $file)){ //if this file is a valid image 
        $files[] = $file; 
       } 
      } 

      closedir($handle); 
     } 
     //sort($files);   
     natcasesort($files); 

     return($files); 
    } 

    $images = returnimages(); //will get the array containing the images 
    foreach($images as $img) 
    { 
     echo '<img src="images/' . $img . '" />'; 
    } 
?> 

</body> 
+1

不錯。開始閱讀http://api.jquery.com/category/ajax/ – Michelle 2012-04-12 22:50:12

+0

這非常有幫助。 – user1325414 2012-04-12 23:07:05

+0

jQuery Cycle在結尾處沒有事件,所以它似乎需要某種破解或擴展才能實現。 ajax調用本身很容易,只需在幻燈片ID和頁面上使用一個負載即可。 – 2012-04-12 23:15:04

回答

0

添加JavaScript到您的頁腳與某些intervalls發送新圖像的請求:

<script> 
    $(function(){ 
     setIntervall("fetchImages()", 20000); 

     function fetchImages() { 
      $.ajax({ 
       type: "GET", 
       url: "yourImageFetchingScript.php" 
      }).done(function(response){ 
       var curImgCount = $('#slideshow img').length; 
       if (response.length > curImgCount) { 
        for (var i = curImgCount; i < response.length; i++) { 
         $('#slideshow').append('<img src="images/' + response[i] + '"');  
        } 
       } 
      }); 
     } 
    }); 
</script> 

然後yourImageFetchingScript.php可能只是打電話給你returnimages功能和JSON編碼的結果:

$images = returnimages(); 
echo json_encode($images); 

查看jQuery的ajax documentation瞭解更多詳情。

+0

Oppps ...錯過了你的週期。使用一些甚至由循環觸發的調用fetchImage而不是setIntervall函數。 – p3n0l 2012-04-12 23:52:39

+0

你能更清楚嗎? – user1325414 2012-04-13 01:14:44

相關問題