在網頁開發中,經常會需要不斷的刷新某個頁面或某個局部數據。這時候就需要用到定時刷新來實現了。實現方式就是使用JS setInterval函數每隔一段時間請求一次數據,然后將請求結果返回給前端HTML實現刷新。
實現代碼如下:
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script><script> $(function(){ getData(); setInterval(function(){ getData(); }, 3000); }); functiongetData(){ $.getJSON("/blood/pressure/1", function(data){ if (200 == data.code) { $("#systolic").text(data.data.systolic); $("#diastolic").text(data.data.diastolic); $("#pulse").text(data.data.pulse); } }); };</script>
代碼解釋:
1. 導入jquery
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
使用上面的語句導入JQuery庫,下面的代碼需要JQuery庫的支持。
2. 頁面加載完啟動程序
$(function(){ getData(); // 第一次加載數據 // 開啟定時任務,時間間隔為3000 ms。 setInterval(function(){ getData(); }, 3000);});
一般定時任務需要在頁面加載完成之后就啟動。頁面加載完成有兩種事件,一是ready,表示文檔結構已經加載完成(不包含圖片等非文字媒體文件),二是onload,指示頁 面包含圖片等文件在內的所有元素都加載完成(可以說:ready 在onload 前觸發)。
建議在ready時就執行定時任務,使用下面的代碼實現:
$(function(){ // do sometion});
上面的代碼等價于:
$(document).ready(function(){ //do something})
3. 獲取數據并刷新頁面
使用下面的代碼獲取數據并設置頁面相應的值。從而刷新頁面數據。這個步驟根據自己的需求寫相應的代碼。
functiongetData(){ $.getJSON("/blood/pressure/1", function(data){ if (200 == data.code) { $("#systolic").text(data.data.systolic); $("#diastolic").text(data.data.diastolic); $("#pulse").text(data.data.pulse); } });};
新聞熱點
疑難解答