如何在 RichFaces/JSF 页面中嵌入和调用 javascript 脚本

2024-03-25

我一直在寻找一种在 JSF 页面中嵌入和调用 javascript 函数的方法。我也在使用 RichFaces。

为了定义该函数,我似乎可以以跨浏览器支持的方式执行此操作:

        <a4j:outputPanel ajaxRendered="true">
        <f:verbatim>
            <script type="text/javascript">
                function datum() {
                    alert("hi");
                }
            </script>
        </f:verbatim>
    </a4j:outputPanel>

但我不确定如何在页面加载时调用此函数,以便它返回的文本嵌入到h:outputPanel。计划是在为客户端提供服务的页面中嵌入一个 js 时钟。注意我没有使用 body 标签,我使用的是faceletsui:composition, f:view(核心)和 RF RIrich:page.

Thanks


无论您使用哪种类型的服务器端标记,当您的页面到达浏览器时,一切都消失了,只剩下 HTML 了。 (至少,最好是这样,否则无论如何都无法工作。)您需要做的是安排“load”事件处理程序调用您的代码。有多种方法可以做到这一点,但最简单的是:

 <f:verbatim>
     <script type="text/javascript">
        window.onload = function() {
            alert("hi");
        }
    </script>
</f:verbatim>

现在,关于初始化页面的另一部分,重要的是 HTML 中最终的内容。您需要安排某种 HTML 容器(一个<div>或其他东西,具体取决于您的页面设计)并且您会希望它具有唯一的“id”属性。然后,您的 Javascript 可以使用“id”来查找元素并设置其内容:

    var elem = document.getElementById("whatever");
    elem.innerHTML = // ... whatever ;

您可能会在“load”函数中执行这些操作。

另外,如果您使用 Facelets 而不是 JSP(这是一种基于 XML 的视图技术),并且您的 JavaScript 包含注释 // 或文字(例如 、&& 等),则需要添加 XML CDATA 节分隔符。带有 XML CDATA 分隔符的示例:

 <f:verbatim>
     <script type="text/javascript">
     //<![CDATA[
        //Comments won't show error now.
        window.onload = function() {
            alert("hi");
        }
    //]]>
    </script>
</f:verbatim>

你可以看到详细的解释何时在这里使用 CDATA。 https://stackoverflow.com/questions/66837/when-is-a-cdata-section-necessary-within-a-script-tag如果您要创建 HTML5 页面,则不需要这些。

快乐编码!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在 RichFaces/JSF 页面中嵌入和调用 javascript 脚本 的相关文章

随机推荐

  • 如何使 Sphinx 尊重使用 __init__.py 将类导入到包中

    我有一个包裹 foo foo py bar py init py foo py 有一个 Foo 类 在 init py 中 我导入了 Foo 类 以便用户可以执行以下操作 from foo import Foo Sphinx 正确地将 Fo
  • 数据库/网站状态的 Web 服务

    我目前正在尝试构建 一个更简单的版本 一个类似于的状态网站亚马逊的服务健康仪表板 http status aws amazon com 基本上 我需要连接大约 3 个数据中心和几个网站 并至少带有向上 向下消息 我最熟悉 C 和一些网络编程
  • 在父 div 中间创建一个 div

    我正在努力保持 chat innerdiv 位于中间 chat maindiv 我可以通过使用百分比值来做到这一点 但我的问题是应该有2px百分比值无法提供的间隙 相对于宽度和高度 为了清楚地理解 请参阅 CSS 代码中的注释 JSbin
  • 如何四舍五入到最接近的千?

    如何将数字四舍五入到最接近的千位 function round var Round it PHP 允许负精度round例如 x round x 3 Uses default mode of PHP ROUND HALF UP 而正精度表示在
  • 如何让d3的translate:translate-drag功能更加流畅?

    In 这个 JSFiddle https jsfiddle net sachid 8d6ht3dL 我已经在 svg 中实现了元素 我希望这组元素可以拖动 并且我已经尝试过d3 drag并使用transform translate 拖动并不
  • 在 AKS 集群中安装 nginx ingress 失败并出现 SyncLoadBalancerFailed 错误

    我有一个带有 Web 应用程序的 AKS 集群 我想配置一个 nginx Ingress 控制器以将应用程序公开到互联网 然后启用 TLS 我一直在关注官方文档 https learn microsoft com en us azure a
  • 当我尝试连接 Box.com 的 API 时,rauth2 解码器无法处理 access_token

    这是我用于连接到 Box 的代码 但我无法让 box storage get auth session data data 工作 从 rauth 导入 OAuth2Service box storage OAuth2Service name
  • 如何在 Android 中处理 3 个嵌套回收器视图中的数据 [Kotlin]

    我有一个由三个回收者视图组成的结构 因此 有一个父回收器视图包含一个子回收器视图 而该子回收器视图又包含一个子回收器视图 为了理解 就像第一个回收者视图是楼层总数 第二个回收者视图是房间总数 第三个回收者视图是设备总数 我有一个房间数据库
  • Objective-C 将数字舍入到最接近的 50

    如何将数字四舍五入到最接近的 X 值 例如 50 IE 47 就是 50 24 将是 0 74 就是 50 99 就是 100 etc 我真的不知道从哪里开始研究如何做到这一点 附 我在 iPhone 上使用 cocoa touch 多谢
  • 使用lambdaify将硬积分转换为lambda函数

    我想对函数进行羔羊化Integral t t t 0 x 它有效 但是我的新函数由lambdify 不返回数字 而仅返回sympy integrals integrals Integral班级 但我不希望这样 我希望它返回一个浮点数 这是我
  • Hibernate 不保存值的集合

    好吧 我现在已经在几个项目中使用了 Hibernate 但在使用它之前我并没有了解它的复杂性 我开始查看使用 JPA 注释并与 Spring 集成的代码 一切运行良好 但现在我想向我的学生教授基本的 Hibernate 并且我正在创建一个示
  • 如何摆脱“从预捆绑文件加载”消息?

    在启动屏幕之后 但在加载应用程序之前 屏幕顶部会出现一条 正在从预捆绑文件加载 消息 持续时间只有几百毫秒 我在开发中不介意这一点 但在手机上运行时我仍然看到此消息 这是我创建捆绑包的方法 有任何想法吗 谢谢 react native bu
  • Cardview Click 未打开活动

    我的问题 no error in this project i can run successful 我的按钮可以在特定时间点击 当我点击回来时 它根本不起作用 我认为我的问题与父母有关 我的项目父级有什么错误 请帮帮我 下面是我的 Jav
  • WCF Web服务流响应的最佳实践

    我正在尝试从 WCF Web 服务中提取大量数据 请求相当小 而响应消息将非常大 目前 由于 IIS6 对其可分配的内存 1 4GB 有限制 Web 服务正在引发 SystemOutOfMemory 异常 我在一些博客中读到 实施流式传输可
  • 如何优雅地降级 CSS 视口单位?

    CSS 视口单位 vw vh vmin vmax 非常棒 我想开始将它们用于字体 但我注意到here http caniuse com viewport units他们没有得到广泛的支持 我尝试在不支持的浏览器中搜索任何用于优雅降级的最佳实
  • ASP.NET MVC 4 参数由正斜杠“/”分隔,未正确传递参数

    我试图遵循许多网站使用的约定 这些网站使用多个正斜杠传递参数 而不是使用 GET 模型 也就是说 我希望使用如下 URL http www foo bar controller action arg1 a arg2 b arg3 c 以这种
  • jquery-select2 ajax搜索在另一个div中显示标签

    我想在另一个 div 中显示所选结果 而不是在输入框中显示 function formatRepo repo if repo loading return repo text var markup div class select2 res
  • 计算出的“goto”是否尊重 C++ 对象的生命周期?

    Regular goto在 C 中尊重对象生命周期 即使用goto跳出块将为适当的局部变量运行析构函数 start NonTrivial object if again goto start will call object NonTriv
  • 为什么oracle区分大小写?

    Oracle 默认区分大小写 而 SQL Server 和 MySQL 等其他数据库默认不区分大小写 这是否有原因 我知道有一些方法可以启用 禁用区分大小写 但 Oracle 与其他数据库不同似乎很奇怪 我还试图了解区分大小写的原因 我可以
  • 如何在 RichFaces/JSF 页面中嵌入和调用 javascript 脚本

    我一直在寻找一种在 JSF 页面中嵌入和调用 javascript 函数的方法 我也在使用 RichFaces 为了定义该函数 我似乎可以以跨浏览器支持的方式执行此操作