您好,登錄后才能下訂單哦!
Bootstrap Table如何實現定時刷新數據功能?今天我們用兩種方法來闡釋這個問題。通過這個問題,希望你能收獲更多。跟隨小編一起來看解決方案吧。
前提:令表格的id為realTimeTable
方法一:毀掉表格,再查詢數據后append,如果你查大量的數據(例如:查詢很多渠道的信息),而獲取服務器數據又太慢,你就會看到表格在一行一行的增加
?定時器,多長時間執行一次,自己定義,此處是30S
setInterval(function() { queryAll(); }, 30000);
?先定義一個函數,里面放入查詢的方法updateRealTimeData和你所自定義使用的方法
function queryAll() { updateRealTimeData(); . . . . }
?方法updateRealTimeData
function updateRealTimeData() { if(errorFlag || appid == -1) return; //把表格的tbody移除,不然后面會一直添加 $("#realTimeTable").bootstrapTable('removeAll'); //獲取數據 $.ajax({ data: { //向服務器發送的一些參數,像日期,游戲ID什么的 . . . . . }, type: "post", //url不用說了吧,否則不知道向服務器哪個接口發送并請求 url: *******, async: true, //超時時間 timeout:30000, success: function(msg) { if(msg.code == '1') { //定義的函數實現對表格賦值,自定義想傳的參數,但別忘了msg,不然搞個屁 showTableData(msg,……); } } }); }
?方法showTableData
function showTableData(msg,……) { tableData = []; for(var i = 0; i < json.length; i++) { tableData.push({ //這里也就是data-field的名稱,getDate是服務器返回的字段名 date: json[i].getDate, . . . . }) //數組反向排列,看情況使用 tableData.reverse(); //向tbody里面添加數據 $("#realTimeTable").bootstrapTable('append', tableData); } }
方法二:使用updateRow方法
?首先,得存在表格,里面有數據,才能更新行,否則沒作用。此方法不會像上面的方法表格消失再增加,這個是整體不變,里面的數據會自動更新
?定時器,和上面一樣,多長時間執行一次,自己定義,此處是30S
setInterval(function() { queryAll(); for (var j = 0; j < 請求的數據的總條數(也就等于表格的行數); j++) { changeAllChannelRealTime(j, .....); } }, 30000); function changeAllChannelRealTime(j, .....) { $.ajax({ data: { //向服務器發送的一些參數,像日期,游戲ID什么的 . . . . . }, type: "post", //url不用說了吧,否則不知道向服務器哪個接口發送并請求 url: *******, async: true, //超時時間 timeout:30000, success: function(msg) { if (msg.code == '1') { changeData(j, msg, .....); } }, error: function () { msgToast.error("查詢數據出錯"); } }); } function changeData(i,msg,......){ $('#realTime_Table').bootstrapTable('updateRow', { //i表示第幾行,從0開始 index: i, row: { //這里也就是data-field的名稱,*表示字段名 date: msg.* . . . . } }); }
上文描述的就是Bootstrap Table實現定時刷新數據功能的詳細內容,具體使用情況還需要大家自己動手實驗使用過才能領會。如果想了解更多相關內容,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。