web開發中有沒有碰到需要適時的將結果輸出到瀏覽器頁面而不刷新整個頁面的需求呢?當你在處理一個過程需要耗時很長,但你又需要適時的知道程序當前的處理狀況的時候,該怎么辦呢?下面就分享一下如何使用php及時的輸出當前結果到瀏覽器而不刷新整個頁面的效果吧。

PHP簡單的輸出代碼

for($i=0;$i<10;$i++){
    echo $i;
    sleep(1);
}

国产视频app上面這段程序如果在PHP解釋器中執行,每秒會輸出一個數,和預計效果一樣。但在瀏覽器中訪問時,結果卻是瀏覽器在十秒之后一次性地顯示了所有結果。對于這個問題,我們可以使用 ob_flush() 和 flush() 來強制刷新瀏覽器緩存,程序改為:

for($i=0;$i<10;$i++){
    echo $i;
    ob_flush();
    flush();
    sleep(1);
}

問題解決,但又出來個問題,瀏覽器還不兼容了。實際測試中只有 Firefox 按預計效果即時輸出了結果,而在 IE  Safari Opera 等瀏覽器中還是一次性的輸出結果。查閱相關資料發現是因為不同的瀏覽器對緩沖的處理方式不同,Firefox 在被要求強制刷新緩存時很聽話,而IE需要在接收到256個字節后才會將內容即時展現在界面上,Safari 需要1024個字節,Opera 更有個性,只有在遇到HTML標簽的時候才會即時輸出(Safari也是如此)。

加入空間字符適配IE

国产视频app對于以上問題,針對IE和Safari,可以在輸出結果之前先輸出大于限定數目的空白字符:

echo str_repeat(" ",1024);
for($i=0;$i<10;$i++){
    echo $i;
    ob_flush();
    flush();
    sleep(1);
}

加入HTML標簽兼容瀏覽器

而對于Opera、Safari遇到HTML標簽后才會即時輸出的問題,我們在代碼中加入一個<br/>換行的HTML標簽,來適配代碼

echo str_repeat(" ",1024);
for($i=0;$i<10;$i++){
    echo $i."<br>";
    ob_flush();
    flush();
    sleep(1);
}

国产视频app至此已基本實現了在各個瀏覽器中達到一致的效果了,至于實際工作中,你可能是另外一種目的但是需要類似這種效果,則只需要根據需要做相應的修改即可。