如何更新页面中显示的值而不刷新

时间:2011-05-02 02:03:25

标签: java javascript ajax jsf jsf-2

我在JSF页面中有这三个字段

<h:inputText id="val1" value="#{managedBean.val1}"/> 
<h:inputText id="val2" value="#{managedBean.val2}"/> 
<h:outputText value="#{managedBean.result}"/>

我还有一个具有以下属性的支持bean:

@ManagedBean
@RequestScoped
public class NewOfferSupportController {

   private String val1;
   private String val2;
   private String result;

//Get set methods...
}

我希望outputText元素在字段val1和val2中插入一些值时自动更改其值,而不刷新页面。 结果变量应以这种方式计算(计算百分比):( val1 * val2)/ 100

你能帮我解决一些疑问吗?:

我知道,为了做到这一点,我需要像javascript或AJAX这样的东西。你认为应该是最好的方法吗?

我很想知道如何用AJAX做到这一点,你能给我一些提示吗?

由于我需要字段为String类型,我的验证应该如何实现?

我可以避免在字段中输入不是数字的字符(如果按下的键不是数字,输入字段中根本不显示)?

2 个答案:

答案 0 :(得分:4)

如果这是简单的计算,不需要服务器调用那么你应该使用客户端javascript解决方案


但是你喜欢在这里使用Ajax,你可以去...

您可以使用<f:ajax>render属性来使用AJAX实现此功能。

<h:form> 
      <h:inputText value="#{managedBean.val1}" > 
         <f:ajax event="keyup" render="result" listener="#{managedBean.someThingToDoListener}"/> 
      </h:inputText> 
      <h:inputText value="#{managedBean.val2}" > 
        <f:ajax event="keyup" render="result" listener="#{managedBean.someThingToDoListener}"/> 
      </h:inputText> 

      <h:outputText id="result" value="#{managedBean.result}"/>
</h:form>

@ManagedBean(name = "managedBean") 
public class Bean { 
   private String val1; // getter and setter 
   private String val2; // getter and setter 
   private String res; // getter and setter 
   ... 

   public void someThingToDoListener(AjaxBehaviorEvent event) { 
       //res = some processing
    }

}

另见

答案 1 :(得分:1)

如果您正在使用java,那么获取JQuery。一旦您使用代码处理并获得了所需的结果,您就可以抓住要放入其中的dom元素并执行以下操作:

$("#result").html(newData);