通过JavaScript函数调用p:remoteCommand,通过"oncomplete"将该函数
Invoking a p:remoteCommand via a JavaScript function passing a message local to that function to another function through the "oncomplete" handler
这个问题纯粹是基于之前问过的问题(礼貌),但是这个问题完全被Java EE 7 WebSockets API弄乱了,它试图展示实际的实用方法/场景,现在不太可能收到任何基于<p:remoteCommand>
的答案。
下面给出一段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>
假设test()
函数中的本地JavaScript变量message
被分配了一个JSON消息,该消息通过WebSockets通道异步接收。
notifyAll()
函数反过来必须向另一个WebSockets通道发送通知消息(myMessage
本地test()
函数-实际上是之前在test()
函数中收到的JSON消息),该通道在此问题中被完全忽略。
是否有可能通过给定<p:remoteCommand>
的oncomplete
处理程序将var message = "myMessage"
的值传递给test()
函数的另一个函数notifyAll()
?
将message
声明为全局JavaScript变量可能会压倒WebSockets的功能,因为消息是异步接收的即,当<p:remoteCommand>
的处理仍在进行/等待完成时,可能会收到新消息。因此,不能将message
声明为全局JavaScript变量。
.
我没有看到比将其作为参数传递到<p:remoteCommand>
函数并从中提取oncomplete
函数更好的方法。
function test() {
var message = "myMessage";
myFunction([{name: "message", value: message}]);
}
function notifyAll(data) {
var message = decodeURIComponent(data.match(/&message=([^&]*)/)[1]);
// ...
}
<p:remoteCommand name="myFunction" ... oncomplete="notifyAll(this.data)" />
data
参数已经被oncomplete
注入到JS函数作用域中,它代表XHR查询字符串。正则表达式从中提取参数。注意,regex假设参数永远不会出现在查询字符串的开头,这是真的,因为它总是以JSF/PF特定的参数开始,所以它可以保持简单(JS regex在反向查找方面很棘手)。
- "访问控制允许起源”;通过javascript从http页面调用同一网站的httpsurl时出现问题
- "未捕获的SyntaxError:意外的令牌ILLEGAL“;当我通过AJAX发送html时
- 通过分离除“”之外的任何特殊字符来获得所有列表框值"通过jquery
- 通过javascript编程设置请求[quot;__EVENTTARGET"]
- "堆叠外空间”;同时通过AJAX调用填充jsTree
- 通过“;类“"实例”;使用ReactJS组件代替“props”文字
- 这里有一种新型的广告javascript通过change"window.opener.location”;,我
- babel节点param前缀为“--"是't通过
- 得到"未捕获错误:断言失败:Ember视图需要1.7和2.1之间的jQuery“;通过ember-cli创建的
- “间歇”;jqLite不支持通过选择器查找元素"当使用RequireJS加载AngularJS时
- 为什么表达式/0+[0-9]/通过了“0”的测试;00f”"f”;是一封信
- 如何在jqGrid中隐藏和显示自定义按钮通过使用"reccount”;
- 为什么我的动画"重放的“;当通过innerHTML添加元素时
- 如何获得类似id的"invokedOn”;使用Bootstrap ContextMenu通过右键单击事件显示文
- <a href="javascript:foo(this)">通过Window,我想要标记
- 当添加“;目标“:"空白“;通过javascript链接,打开的选项卡是“;回收的“;(重复使用)-以任何方式
- "OnClick”;通过JavaScript创建的事件会立即触发,而不是在单击对象时触发
- 得到"操作不安全”;通过tinymce添加tinymce时出错.EditorManager.execComma
- "旧的“;当通过javascript选中时,手机不会显示复选框复选标记
- 如何实现“无线电”通过“button"