监控整页,非AJAX,要求通知
最近,在JSF中開發新圖表和圖表“導出服務”時,我遇到了一個非常普遍的問題。 當您執行長時間運行的任務(操作)時,您希望在開始時顯示狀態“請稍候……”對話框,并在響應到達時最后關閉此對話框。 對于AJAX請求,這不是問題,但對于將一些二進制內容流式傳輸到瀏覽器的非AJAX請求而言,則是有問題的。 為了解決此問題,我們可以使用與PrimeFaces中的FileDownload組件相同的技術。 我們可以設置一個特殊的cookie作為響應,并在客戶端定期檢查此cookie(如果已設置)。 設置此Cookie后,我們可以關閉打開的“之前”對話框。 可以在JSF中將cookie設置為:
Non AJAX按鈕執行一個JavaScript函數(例如monitorExporting),它具有兩個參數,這些參數代表在請求/響應生命周期的開始和結束時要調用的另一個JavaScript函數。
<p:commandButton value="Export to PNG" ajax="false" action="#{combiChartController.exportToPng}"onclick="monitorExporting(start, stop)"/>PrimeFaces已經提供了一些方法來檢查是否啟用了cookie,以獲取和刪除它們。 所以,我們可以寫
function monitorExporting(start, complete) {if(PrimeFaces.cookiesEnabled()) {if(start) {start();}window.chartExportingMonitor = setInterval(function() {var exportingComplete = PrimeFaces.getCookie('cookie.chart.exporting');if(exportingComplete === 'true') {if(complete) {complete();}clearInterval(window.chartExportingMonitor);PrimeFaces.setCookie('cookie.chart.exporting', null);}}, 150);} }使用setInterval(…)定期詢問cookie。 功能開始顯示“請稍候……”對話框,功能停止將其關閉。
<script type="text/javascript"> /* <![CDATA[ */function start() {statusDialog.show();}function stop() {statusDialog.hide();} /* ]]> */ </script> 如果禁用了cookie,則當然不會顯示任何內容,但是通常很少見。
翻譯自: https://www.javacodegeeks.com/2013/07/monitor-full-page-non-ajax-requests-to-be-notified.html
總結
以上是生活随笔為你收集整理的监控整页,非AJAX,要求通知的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: DDOS攻击行为(ddos攻击的行为)
- 下一篇: 祖父用英语怎么说 祖父英语解释