html - 我的網站是用PHP+MySQL+Javascript做的,用來對動態資料進行即時顯示,現在想在主介面做一個警報燈,求大神指點!

WBOY
發布: 2016-09-28 08:54:11
原創
1599 人瀏覽過

html - 我的網站是用PHP+MySQL+Javascript做的,用來對動態資料進行即時顯示,現在想在主介面做一個警報燈,求大神指點!

回覆內容:

html - 我的網站是用PHP+MySQL+Javascript做的,用來對動態資料進行即時顯示,現在想在主介面做一個警報燈,求大神指點!

目前是兩種成熟的解決方案, Ajax 輪詢和 Web Socket,當然推薦後者。

至於樓上說你的Web是由PHP服務端腳本開發,很遺憾Web Socket並不能與PHP建立通訊,以我的經驗來看,這是錯的。

我個人實踐過了(線上專案和命令列的 Web Socket都是可以實現的,就是 PHP 寫的), Web Socket 在 PHP 中應用完全沒有問題,這基本上是跟語言無關的。 PHP 中的 walkerman 和 swoole 你可以看看。

或你選擇這個:http://socket.io/ 結合 redis 就可以實現。

前端不刷新頁面獲得事實資料目前只有兩種技術,Ajax與Web Socket。這需要對比這兩種技術的區別,Ajax是完全的基於Web的數據獲取技術,也就是說它能獲得的數據實際上是一個Web的服務端腳本能夠利用url反饋的結果,很明顯很符合你目前的使用,準確的說是設計比較簡單。但是Ajax技術有很大的弊端是它只能被動式獲取信息,什麼是被動式獲取信息?和你的應用場景結合一下,溫度在變化,什麼時候會變化?何時更新數據?很顯然,前端的js腳本是不能預測的,它唯一能做的是設定一個計時器,間隔n(毫)秒獲取一次資料。當次與上次資料改變時,即可更新圖表。這樣的被動式就會出現一個問題,取得間隔時間太長,難以體現「即時」數據,間隔時間太短,載入了大量無用資訊(即當次與前次數據相同),因此增大了伺服器的處理負擔。那麼,有什麼更好的解決方法呢?當然是有的,基於前端開發的Web Socket解決了這個問題。它與伺服器建立一條通訊線路,無論是哪一方都可以主動發出訊息,接收者可以即時的回饋結果。那為什麼說這項技術不能使用在你目前的應用上?首先,你的Web是由PHP服務端腳本開發,很遺憾Web Socket並不能與PHP建立通訊。你所需要的是基於服務端開發一個能夠具有主動請求的服務端腳本例如Java Socket Server。具體如何搭建,本文不會過多敘述。

不是大神,建議可以透過AJAX的方式異步獲取,前段的話,顯示的方式就看你自己的需要設計了。

定時ajax讀一下,例如每隔一分鐘或十秒鐘

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板