這個問題純粹是基於this之前問過的問題(courtesy),但問題與Java完全混淆了EE 7 WebSockets API嘗試顯示實際的方法/場景,現在很難接收基於<p:remoteCommand>
的任何答案。通過JavaScript函數調用ap:remoteCommand,通過「oncomplete」處理函數將本地消息傳遞給另一個函數
下面給出了一段JavaScript代碼(這只是一個測試場景)。
<script type="text/javascript">
function test() {
var message = "myMessage";
window["myFunction"]();
// This is literally interpreted as a JavaScript function "myFunction()".
// "myFunction()" in turn is associated with a <p:remoteCommand>.
}
$(document).ready(test);
function notifyAll() {
alert("notifyAll() invoked.");
}
</script>
的test()
函數只要頁面加載這導致以下<p:remoteCommand>
觸發繼而調用另一個JavaScript功能,即notifyAll()
,使用oncomplete
處理程序簡單地提醒所述消息調用。
<h:form>
<p:remoteCommand process="@this"
name="myFunction"
actionListener="#{bean.listener}"
oncomplete="notifyAll()"
ignoreAutoUpdate="true"/>
</h:form>
假設本地JavaScript變量message
的test()
函數內分配有異步通過的WebSockets信道接收的JSON消息。
反過來notifyAll()
函數必須發送通知消息(myMessage
本地的test()
功能 - 實際上這是在test()
功能先前接收的JSON消息)發送到另一個的WebSockets信道,其在這個問題爲了簡潔完全忽略。
是否有可能通過oncomplete
處理程序給定<p:remoteCommand>
來的var message = "myMessage"
本地的test()
函數值傳遞給另一個函數notifyAll()
?
聲明message
作爲全局JavaScript變量可能壓倒的WebSockets作爲消息的功能被接收異步即可以接收到新的消息而<p:remoteCommand>
處理仍在繼續/等待完成。因此,將message
聲明爲全局JavaScript變量不是一種選擇。
。
'data'從哪裏來?我正在'undefined'。 – Tiny
對不起,我忘了答案中的「
」位。 – BalusC
接收'未捕獲的ReferenceError:未定義數據'。生成的腳本如下所示:''。 – Tiny