seam中方便地使用el表达式

1)直接由表达式字符串生成javax.el.ValueExpression和javax.el.MethodExpression,主要适用于动态构造jsf组件
org.jboss.seam.core.Expressions
@Name("org.jboss.seam.core.expressions")


Expressions.instance().createValueExpression("#{var11.address}").toUnifiedValueExpression()
Expressions.instance().createMethodExpression("#{var11.f1()}").toUnifiedMethodExpression()
主要适用于动态构造jsf组件,给组件属性设置表达式。
javax.faces.component.html.HtmlOutputText out2=new javax.faces.component.html.HtmlOutputText();
out2.setValueExpression("value", Expressions.instance().createValueExpression("#{var11.city}").toUnifiedValueExpression());
2)在seam组件中直接执行el表达式,就像在页面组件中一样。
Expressions.instance().createMethodExpression("#{search.refresh()}").invoke();
List newList=(List)Expressions.instance().createValueExpression(("#{search.resultList}").getValue();
3)将java对象转成表达式,使得java对象可以直接在表达式中使用,比如seam扩展的jpa查询语句中可以插入表达式,针对in or需要list的查询语句特别有意义。当in list时不需要把list中的内容转换成字符串
h.xzqh in (#{list})这样就可以了,我们需要的就是将list对象转成表达式即可

Expressions.instance().createValueExpression(("#{list}").setValue(list);
em.createQuery(".....where ....h.xzqh in (#{list})").getResultList();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值