当前位置: 首页 > 面试题库 >

如何将JSF托管的bean属性传递给JavaScript函数?

贾飞鸿
2023-03-14
问题内容

我想知道如何将JSF托管的bean属性传递给JavaScript函数。

像这样:

<script>
  function actualizaMenu(key){
    #{linkedMenu.setKey(key)}
  }
</script>



<ul>
  <ui:repeat value="#{moduleList.modulos}" var="entity">
    <li>
      <a onclick="actualizaMenu(#{entity.key})">#{entity.nombre}</a>
    </li>
  </ui:repeat>
</ul>

问题答案:

这不是JSF变量的“传递”。这只是打印JSF变量,就好像它们是JavaScript变量/值一样。您知道,JSF和JS根本不同步运行。JSF在Web服务器中运行,并生成HTML/ CSS / JS代码,一旦到达该代码,该代码又在Webbrowser中运行。

您的具体问题很可能是由于您以这种方式生成无效JS语法的方式编写了JSF代码而引起的。一种简单的验证方法是,只需检查JSF生成的HTML输出,您可以通过右键单击,在浏览器中
查看源 来找到,并检查在浏览器的JS控制台中是否看不到任何语法错误报告,您可以通过在Chrome/IE9+/Firefox23+中按F12查找。

试想一下,#{entity.key}在这里

<a onclick="actualizaMenu(#{entity.key})">#{entity.nombre}</a>

打印一个Javahtml" target="_blank">字符串变量,例如"foo",然后生成的HTML看起来像

<a onclick="actualizaMenu(foo)">some name</a>

但是,嘿,这代表一个名为的JavaScript 变量foo,而不是JS字符串值!因此,如果您实际上想要最终以

<a onclick="actualizaMenu('foo')">some name</a>

那么您应该指示JSF完全生成该HTML:

<a onclick="actualizaMenu('#{entity.key}')">#{entity.nombre}</a>

但是要当心JSF变量中的特殊字符。您可以使用OmniFacesof:escapeJS()函数。

具体问题 无关
,具体实现actualizaMenu()没有任何意义。您似乎正在尝试设置bean属性。您不应为此使用JS,而应使用JS
<h:commandLink>

<h:commandLink value="#{entity.nombre}" action="#{linkedMenu.setKey(entity.key)}" />

如果需要,请嵌套<f:ajax>以使其异步。



 类似资料:
  • 托管bean它是一个纯Java类,它包含一组属性和一组,方法。 以下是托管bean方法执行的常见功能: 验证组件的数据 处理组件触发的事件 执行处理以确定应用程序必须导航的下一页 它也可以作为JFS框架的模型。 JSF托管Bean示例 请看看下面一段示例代码 - 您可以通过以下方式使用此。 通过配置成XML文件。 通过使用注释。 通过XML文件配置托管Bean 在xml文件配置是比较旧方法。 在这

  • 我正计划将一个web应用程序从使用JSF托管bean转换为使用CDI托管bean。我知道我需要做以下工作: 在WEB-INF中添加空beans.xml文件。 将所有JSF@ManagedBean替换为CDI@Named Annotations。 用CDI或OmniFaces作用域注释替换所有JSF作用域注释。 将所有JSF@ManagedProperty替换为CDI@Inject Annotati

  • 主要内容:使用XML配置,使用@ManagedBean注解JSF 托管bean(Managed Bean)是JSF注册的常规Java Bean类。托管bean包含getter和setter方法,业务逻辑。JSF托管bean作为UI组件的Model。 它存储JSF xhtml页面使用的数据。借助JSF框架,可以从JSF页面访问托管Bean。 在JSF 1.2中,我们必须在JSF配置文件(如)中注册受管理的bean。 从JSF 2.0可以使用注解注册管理be

  • 问题内容: 这是我的问题: 当我用JavaScript编写此代码时 // 好: 但是,当我尝试在属性标签中动态设置该值时,没有任何执行。 // 不好: 有人可以帮我吗? 问题答案: Struts标签,例如JSTL,EL等,是在服务器端执行的。执行完所有这些步骤后,仅HTML的最终页面将呈现给客户端。只有这样,JavaScript才能在页面上运行。 您不能混合使用javascript和Struts标

  • 问题内容: 这是我的问题: 当我用JavaScript编写此代码时 // 好: 但是,当我尝试在属性标签中动态设置该值时,没有任何执行。 // 不好: 有人可以帮我吗? 问题答案: Struts标签,例如JSTL,EL等,是在服务器端执行的。执行完所有这些步骤后,仅HTML的最终页面将呈现给客户端。只有这样,JavaScript才能在页面上运行。 您不能混合使用javascript和Struts标

  • 问题内容: 在我的HTML文件中,我已通过以下方式链接到JS: 我的JS可以像这样直接读取此var的值吗? 这不起作用,并且FireFox错误控制台显示“未定义配置”。如何读取JS文件中通过src属性传递的var?这样简单吗? 问题答案: 您无法按照尝试的方式将变量传递给JS。SCRIPT标记不会创建Window对象(具有查询字符串),并且它不是服务器端代码。