【发布时间】:2015-04-17 03:14:15
【问题描述】:
我试图让两个 Javascript 函数在用户从 p:calendar 中选择日期后立即被调用。
不幸的是,只有当用户在文本字段中手动输入日期并向前跳动时,才会处理 onchange 事件。 onselect 事件根本没有被触发。
xhtml如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:p="http://primefaces.org/ui">
<h:head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<h:outputScript library="js" name="custom.js" target="body" />
</h:head>
<h:body>
<p:log />
<h:form id="someForm">
<p:panelGrid columns="2">
<p:outputLabel for="myCalendar" value="Date: " />
<p:calendar id="myCalendar" onchange="alertDateSelected()" onselect="alertSelectEvent()" showOn="button" />
</p:panelGrid>
</h:form>
</h:body>
</html>
onselect 和 onchange 事件的 Javascript 代码:
function alertDateSelected() {
PrimeFaces.info('Selected date from p:calendar');
}
function alertSelectEvent() {
PrimeFaces.info('Clicked p:calendar date selection button');
}
是否有可能挂钩到 p:calendar 上的 onchange/onselect 事件;例如如果用户从日历面板或通过“今天”按钮选择日期?如果是这样,我做错了什么?
【问题讨论】:
-
您确定您的 javascript 位于正确的位置并因此被正确加载吗?你应该在你的 javascript 控制台中寻找线索
-
@kolossus 是的,我确定。如果添加
<p:inputText id="myInput" onchange="alertDateSelected()"/>,则会触发 onchange 事件,您可以在 PrimeFaces 日志中看到预期的输出。向函数添加断点后,报告的行为得到确认:如果处理p:inputText,脚本将停止,但如果处理p:calendar,则不会停止。如果事件没有被触发,请告诉我如何从控制台获取线索。我在哪里可以找到这方面的提示?
标签: javascript primefaces