java – 如何更新页面中显示的值而不刷新
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java – 如何更新页面中显示的值而不刷新,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1654字,纯文字阅读大概需要3分钟。
内容图文
![java – 如何更新页面中显示的值而不刷新](/upload/InfoBanner/zyjiaocheng/710/9604d07f518943f38766759757a18849.jpg)
我在JSF页面中有这3个字段
<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类型,我的验证将如何实现?
我可以避免在字段中输入不是数字的字符(如果按下的键不是数字,输入字段中根本不显示)?
解决方法:
如果这是简单的计算,不需要服务器调用那么你应该使用客户端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
}
}
也可以看看
> JSF2: Ajax in JSF – using f:ajax tag
内容总结
以上是互联网集市为您收集整理的java – 如何更新页面中显示的值而不刷新全部内容,希望文章能够帮你解决java – 如何更新页面中显示的值而不刷新所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。