是否有一种方法可以在调用带有Primefaces RequestContex的其他组件之后设置组件焦点?
我试过:
RequestContex.getCurrentInstance().execute("PF('WidgetVar').focus();");
和
RequestContex.getCurrentInstance().execute("(((InputText) event.getComponent()).getWidgetVar()).focus();");
我没有错误,但什么也没有发生。
我错过了什么吗?这不可能吗?
我使用Primefaces 4.0.3和MyFaces 2.0.2
编辑示例代码
豆子
import java.io.Serializable;
import java.util.logging.Logger;
import javax.annotation.PostConstruct;
import org.primefaces.context.RequestContext;
public class NavigationBean implements Serializable {
private static final long serialVersionUID = 1L;
private String input;
public NavigationBean() {}
@PostConstruct
public void init() {
}
public void goNext() {
Logger.getAnonymousLogger().warning("GONEXT");
RequestContext.getCurrentInstance().scrollTo("w3");
}
public String getInput() {
return input;
}
public void setInput(String input) {
this.input = input;
}
}
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:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:p="http://primefaces.org/ui">
<h:head>
</h:head>
<h:body >
<h:form id="form">
<h:inputText id="input1" value="#{navigationBean.input}" widgetVar="w1"></h:inputText>
<h:inputText id="input2" value="#{navigationBean.input}" widgetVar="w2"></h:inputText>
<h:inputText id="input3" value="#{navigationBean.input}" widgetVar="w3"></h:inputText>
<h:inputText id="input4" value="#{navigationBean.input}" widgetVar="w4"></h:inputText>
<p:commandButton value="focus" action="#{navigationBean.goNext()}" />
</h:form>
</h:body>
</html>
发布于 2015-03-25 05:45:38
如果前面的答案不起作用,您可以创建一个js函数,例如:
function focusField(id){
$(id).focus();
}
然后在您的bean中,假设您希望将焦点设置在字段"input4“上,它表示ID而不是Widgetvar
RequestContext.getCurrentInstance().execute("focusField('#input4');");
发布于 2017-12-11 07:56:27
使用PrimeFaces 6.1时,由于未知的原因,我无法使primefaces :focus工作。因此,我刚刚实现了一个onload JQuery函数来将焦点设置为p:commandButton。对于onload调用,将jQuery嵌套函数放在'body‘下面。这将确保覆盖任何其他primefaces函数。
<script>
jQuery(document).ready(function () {
jQuery(document).ready(function () {
// twice in document.ready to
// execute after Primefaces callbacks
PF('widget_home_page_form_command_button').getJQ().focus();
});
});
</script>
PrimeFaces为所有primefaces组件创建widgetVar组件。有些特性可以通过widgetVar获得,例如禁用或启用。但是,我不得不使用getJQ()函数来获取jQuery对象,并使用该对象在命令按钮上设置焦点。
发布于 2013-12-15 10:10:37
看上去你在这里有几个误解:
RequestContext
代码。
RequestContext.getCurrentInstance().execute("(((InputText) event.getComponent()).getWidgetVar()).Focus();");
你不能。上面的代码不起作用。execute
只为JavaScript构建。focus()
。JS是区分大小写的。所以Focus <> focus
。所以我觉得你应该拥有的
RequestContext.getCurrentInstance().execute("yourClientSideId.focus();");
其中yourClientSideId
应该对应于您感兴趣的组件的widgetVar
属性。我不知道您在代码中引用的PF
对象应该是什么。我从没见过。也许你指的是PrimeFaces
对象?在发生上述故障时,可以始终在scrollTo
上使用RequestContext
方法。
RequestContext.getCurrentInstance().scrollTo("yourComponentWidgetVar");
https://stackoverflow.com/questions/20567620
复制相似问题