1

私は何日も問題に苦労していて、それを機能させるために何をすべきかわかりません。javascriptで動作するTomahawkコンポーネントを使用しようとしています...そして常にjavascriptエラーが発生します:「xxxが定義されていません」(たとえば、xxx = orgApacheMyfacesPopup)。

私の知る限り、これは拡張フィルターの問題のようです。サーバーは、必要な定義を含む.jsを提供できません...しかし、何が問題なのかわかりません。

Eclipseを使って最初から小さなプロジェクトを実行したところ、常にエラーが発生します。

私が従った手順は次のとおりです。

  1. 新しいWebアプリケーションプロジェクトを作成します(Tomcat 6を対象とし、Myfaces2をダウンロードするJSF2.0のサポートを追加します)
  2. jsstl-api-1.2.jarおよびjstl-impl-1.2.jarをダウンロードしてWEB-INF/libにコピーします
  3. JSF2用のTomahawkをダウンロードし、jarファイルをWEB-INF/libにコピーします。
  4. web.xmlを変更します(後に配信されます)
  5. index.xhtmlを作成します(後に配信されます)

私のweb.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0">
    <display-name>TestTomahawk</display-name>
  <servlet>
    <servlet-name>Faces Servlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Faces Servlet</servlet-name>
    <url-pattern>/faces/*</url-pattern>
  </servlet-mapping>
  <context-param>
    <param-name>javax.servlet.jsp.jstl.fmt.localizationContext</param-name>
    <param-value>resources.application</param-value>
  </context-param>
  <context-param>
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
    <param-value>client</param-value>
  </context-param>
  <context-param>
    <param-name>org.apache.myfaces.ALLOW_JAVASCRIPT</param-name>
    <param-value>true</param-value>
  </context-param>
  <context-param>
    <param-name>org.apache.myfaces.PRETTY_HTML</param-name>
    <param-value>true</param-value>
  </context-param>
  <context-param>
    <param-name>org.apache.myfaces.DETECT_JAVASCRIPT</param-name>
    <param-value>false</param-value>
  </context-param>
  <context-param>
    <param-name>org.apache.myfaces.AUTO_SCROLL</param-name>
    <param-value>true</param-value>
  </context-param>
  <listener>
    <listener-class>org.apache.myfaces.webapp.StartupServletContextListener</listener-class>
  </listener>

  <filter>
    <filter-name>MyFacesExtensionsFilter</filter-name>
    <filter-class>org.apache.myfaces.webapp.filter.ExtensionsFilter</filter-class>
        <init-param>
      <param-name>uploadMaxFileSize</param-name>
      <param-value>20m</param-value>
    </init-param>
  </filter>

  <filter-mapping>
    <filter-name>MyFacesExtensionsFilter</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
  </filter-mapping>

  <filter-mapping>
    <filter-name>MyFacesExtensionsFilter</filter-name>
    <url-pattern>/faces/myFacesExtensionResource/*</url-pattern>
  </filter-mapping>
</web-app>

私のindex.xhtmlファイル:

    <html   xmlns="http://www.w3.org/1999/xhtml"
        xmlns:ui="http://java.sun.com/jsf/facelets"
        xmlns:h="http://java.sun.com/jsf/html"
        xmlns:f="http://java.sun.com/jsf/core"
        xmlns:t="http://myfaces.apache.org/tomahawk"
        xmlns:c="http://java.sun.com/jsp/jstl/core"
        >
    <body>
        <h:form>
            <t:popup    styleClass="popup"
                    closePopupOnExitingElement="false"
                        closePopupOnExitingPopup="false"
                        displayAtDistanceX="0"
                        displayAtDistanceY="0"
                        >
                <h:outputText value="test popup" />
                <f:facet name="popup">
                    <h:panelGroup>
                        <h:outputText     value="foo"/>
                    </h:panelGroup>
                </f:facet>
            </t:popup>
        </h:form>
    </body>
</html>

なぜそれが機能しないのか誰かが理解していますか?

PS:Tomecat 7を試してみましたが、うまくいきません...

ありがとう


誰でもない ?Myfaces2とtomahawk2をjavascriptとxhtmlで動作させる人はいますか?誰かがそれのサンプルを見つける場所を知っていますか?MyFaces Webサイトのサンプルは、JSF1.1およびJSPのようなページを対象としているようです...

4

1 に答える 1

1

JSFコンポーネントに固有のJavaScript(およびCSS)ファイルを自動インクルードするために、の<h:head>代わりに必要です。<head>さらに、できれば。にも置き換える必要があり<body>ます<h:body>

適切なFaceletテンプレートは次のようになります。

<!DOCTYPE html>
<html lang="en"
    xmlns="http://www.w3.org/1999/xhtml"
    xmlns:f="http://java.sun.com/jsf/core"
    xmlns:h="http://java.sun.com/jsf/html"
    xmlns:ui="http://java.sun.com/jsf/facelets"
    xmlns:t="http://myfaces.apache.org/tomahawk">
    <h:head>
        <title>Title</title>
    </h:head>
    <h:body>
        <h1>Body</h1>
    </h:body>
</html>
于 2011-08-22T12:45:45.153 に答える