Bootstrap Table如何實現(xiàn)定時刷新數(shù)據(jù)功能?今天我們用兩種方法來闡釋這個問題。通過這個問題,希望你能收獲更多。跟隨小編一起來看解決方案吧。
創(chuàng)新互聯(lián)自2013年創(chuàng)立以來,先為倉山等服務建站,倉山等地企業(yè),進行企業(yè)商務咨詢服務。為倉山企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務解決您的所有建站問題。
前提:令表格的id為realTimeTable
方法一:毀掉表格,再查詢數(shù)據(jù)后append,如果你查大量的數(shù)據(jù)(例如:查詢很多渠道的信息),而獲取服務器數(shù)據(jù)又太慢,你就會看到表格在一行一行的增加
?定時器,多長時間執(zhí)行一次,自己定義,此處是30S
setInterval(function() { queryAll(); }, 30000);
?先定義一個函數(shù),里面放入查詢的方法updateRealTimeData和你所自定義使用的方法
function queryAll() { updateRealTimeData(); . . . . }
?方法updateRealTimeData
function updateRealTimeData() { if(errorFlag || appid == -1) return; //把表格的tbody移除,不然后面會一直添加 $("#realTimeTable").bootstrapTable('removeAll'); //獲取數(shù)據(jù) $.ajax({ data: { //向服務器發(fā)送的一些參數(shù),像日期,游戲ID什么的 . . . . . }, type: "post", //url不用說了吧,否則不知道向服務器哪個接口發(fā)送并請求 url: *******, async: true, //超時時間 timeout:30000, success: function(msg) { if(msg.code == '1') { //定義的函數(shù)實現(xiàn)對表格賦值,自定義想傳的參數(shù),但別忘了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, . . . . }) //數(shù)組反向排列,看情況使用 tableData.reverse(); //向tbody里面添加數(shù)據(jù) $("#realTimeTable").bootstrapTable('append', tableData); } }
方法二:使用updateRow方法
?首先,得存在表格,里面有數(shù)據(jù),才能更新行,否則沒作用。此方法不會像上面的方法表格消失再增加,這個是整體不變,里面的數(shù)據(jù)會自動更新
?定時器,和上面一樣,多長時間執(zhí)行一次,自己定義,此處是30S
setInterval(function() { queryAll(); for (var j = 0; j < 請求的數(shù)據(jù)的總條數(shù)(也就等于表格的行數(shù)); j++) { changeAllChannelRealTime(j, .....); } }, 30000); function changeAllChannelRealTime(j, .....) { $.ajax({ data: { //向服務器發(fā)送的一些參數(shù),像日期,游戲ID什么的 . . . . . }, type: "post", //url不用說了吧,否則不知道向服務器哪個接口發(fā)送并請求 url: *******, async: true, //超時時間 timeout:30000, success: function(msg) { if (msg.code == '1') { changeData(j, msg, .....); } }, error: function () { msgToast.error("查詢數(shù)據(jù)出錯"); } }); } function changeData(i,msg,......){ $('#realTime_Table').bootstrapTable('updateRow', { //i表示第幾行,從0開始 index: i, row: { //這里也就是data-field的名稱,*表示字段名 date: msg.* . . . . } }); }
上文描述的就是Bootstrap Table實現(xiàn)定時刷新數(shù)據(jù)功能的詳細內(nèi)容,具體使用情況還需要大家自己動手實驗使用過才能領會。如果想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!