我們在一些應用中需要動態展示數據,比如當前在線人數,當前交易總額,當前匯率等等,前端頁面需要實時刷新獲取最新數據。本文將結合實例給大家介紹使用jQuery和PHP來實現動態數字展示效果。
本例假設要在頁面上動態展示(無需刷新整個頁面,只是局部刷新動態數字)當前在線用戶數,常見在一些統計平台上應用。在HTML頁面中只需定義以下結構:
<div class="count">當前在線:<span id="number"></span></div>
首先我們要定義一個動畫過程,使用jQuery的animate()函數實現從一個數字到另一個數字的變換過程,以下magic_number()自定義函數將代碼整合如下:
function magic_number(value) { var num = $("#number"); num.animate({count: value}, { duration: 500, step: function() { num.text(String(parseInt(this.count))); } }); };
然後update()函數使用了jQuery的$.getJSON()向後台number.php發送了一個ajax請求,在得到PHP相應後,調用magic_number()展示最新的數字。為了能看到更好的效果,我們使用setInterval()設置代碼執行的間隔時間。
function update() { $.getJSON("number.php?jsonp=?", function(data) { magic_number(data.n); }); }; setInterval(update, 5000); //5秒鐘執行一次 update();
PHP部分
實際項目中,我們會使用PHP獲取數據庫中的最新數據,然後通過PHP返回給前端。本例為了更好的演示,使用隨機數字,最後以json格式返回給前端js,number.php代碼如下:
$total_data = array( 'n' => rand(0,999) ); echo $_GET['jsonp'].'('. json_encode($total_data) . ')';
原理其實非常的簡單就是利用js settimeout實現過幾秒加載一個php文件從而達到了實時顯示在線人數的功能了。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!