2016-12-23 10 views
0

スタイルとスクリプトのリストを継承できる基本定義を定義できます。基本定義を継承するページ定義を定義し、ページ固有のスタイルとスクリプトを追加します。これは可能でしょうか?これについて正しい方法で考えていないのですか?私はこれをかなり基本的な考えであると思っていたでしょう。タイル3 put属性の別の定義を参照する方法

基本定義

<tiles-definitions> 
    <!-- base styles --> 
    <definition name="base.styles" > 
     <put-list-attribute name="styles" cascade="true" > 
      <add-attribute value="/view/common/jquery-ui-theme-base-v1.12.1.css" /> 
     </put-list-attribute> 
    </definition> 
    <!-- base scripts --> 
    <definition name="base.scripts" > 
     <put-list-attribute name="scripts" cascade="true" > 
      <add-attribute value="https://code.jquery.com/jquery-3.1.0.min.js" /> 
      <add-attribute value="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js" /> 
     </put-list-attribute> 
    </definition> 
    <!-- base definition --> 
    <definition name="base.definition" template="/WEB-INF/page/defaultLayout.jsp" > 
     <put-attribute name="title" /> 
     <put-attribute name="styles" value="base.styles.styles" cascade="true" /> 
     <put-attribute name="header" value="/WEB-INF/page/common/header.jsp" /> 
     <put-attribute name="body" /> 
     <put-attribute name="scripts" value="base.scripts.scripts" cascade="true" /> 
     <put-attribute name="footer" value="/WEB-INF/page/common/footer.jsp" /> 
    </definition> 
</tiles-definitions> 

ノートプット属性の値は、それらの上の定義の名前と一致します。

ページ固有の定義

<tiles-definitions> 
    <!-- page specific styles --> 
    <definition name="samplePage.styles" extends="base.styles" > 
     <put-list-attribute name="styles" inherit="true" > 
      <add-attribute value="/view/page/samplePage/samplePageStyles.css" /> 
     </put-list-attribute> 
    </definition> 
    <!-- page specific scripts --> 
    <definition name="samplePage.scripts" extends="base.scripts" > 
     <put-list-attribute name="scripts" inherit="true" > 
      <add-attribute value="/view/page/samplePage/samplePageScript.js" /> 
     </put-list-attribute> 
    </definition> 
    <!-- page specific definition --> 
    <definition name="samplePage" extends="base.definition" > 
     <put-attribute name="title" value="Sample Page" /> 
     <put-attribute name="styles" value="samplePage.styles" cascade="true" /> 
     <put-attribute name="body" value="/WEB-INF/page/samplePage/samplePageBody" /> 
     <put-attribute name="scripts" value="samplePage.scripts" cascade="true" /> 
    </definition> 
</tiles-definitions> 

(私の推測では、これは正しくないです)、再びプット属性の値は、それらの上の定義の名前と一致 - 注。 (おそらく修正していない?)私は現在はIllegalArgumentExceptionスタイルとスクリプトのプットの属性は、それらの上に同じ名前の定義を拾っていないかのようにそれが表示されます

Caused by: java.lang.IllegalArgumentException: Cannot convert samplePage.styles of type class java.lang.String to class org.apache.tiles.Attribute 
at com.sun.el.lang.ELSupport.coerceToType(ELSupport.java:428) 
at com.sun.el.ExpressionFactoryImpl.coerceToType(ExpressionFactoryImpl.java:85) 
... 104 more 

を取得しています

...しかし、私はそれを修正するために何をすべきか分からない。何か案は?

答えて

0

プット属性で別の定義を参照する方法を質問に答えるために、これは、以下の(ノートの定義、および「タイプ」属性)として、JSPコンポーネントとかなり簡単にできるように表示されます。

彼らはTRANないとして、その後別の場所
<definition name="default.header" template="/WEB-INF/page/common/header.jsp" /> 

... ...

<put-attribute name="header" type="definition" value="default.header" /> 

しかし、それはこのように見えないが、そのようなスタイルシートやスクリプトなどのリソースで行うことができます実際のテンプレートに戻ってください。だから私は基本定義を次のように改訂しました。それでも、「グローバル」リソースと「ページ固有の」リソースを持つことができます。また、jspコンポーネントを一度記述し、一度定義して何度も参照することもできます。

共通定義(tiles.common.xml)

<tiles-definitions> 
    <definition name="default.header" template="/WEB-INF/page/common/header.jsp" /> 
    <definition name="default.footer" template="/WEB-INF/page/common/footer.jsp" /> 

    [... all the other common components...] 

</tiles-definitions> 

ベース定義(tiles.base.xml)

<tiles-definitions> 
    <definition name="base.definition" template="/WEB-INF/page/baseLayout.jsp" > 
     <put-attribute name="title" type="string" /> 
     <put-attribute name="header" type="definition" value="default.header" /> 
     <put-attribute name="body" /> 
     <put-attribute name="footer" type="definition" value="default.footer" /> 
     <put-list-attribute name="styles" inherit="true" > 
      <add-attribute value="/view/common/jquery-ui-theme-base-v1.12.1.css" /> 

      [... other styles common to all pages...] 

     </put-list-attribute> 
     <put-list-attribute name="scripts" inherit="true" > 
      <add-attribute value="https://code.jquery.com/jquery-3.1.0.min.js" /> 
      <add-attribute value="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js" /> 

      [... other scripts common to all pages...] 

     </put-list-attribute> 
    </definition> 
</tiles-definition> 

ページ特定の定義(tiles.samplePage.xml )

<tiles-definitions> 
    <definition name="samplePage" extends="base.definition" > 
     <put-attribute name="title" value="Sample Page" /> 
     <put-attribute name="body" value="/WEB-INF/page/samplePage.jsp" /> 
     <put-list-attribute name="styles" inherit="true" > 
      <add-attribute value="/view/pages/samplePage.css" /> 

      [... other page specific styles ...] 

     </put-list-attribute> 
     <put-list-attribute name="scripts" inherit="true" > 
      <add-attribute value="/view/pages/samplePage.js" /> 

      [... other page specific scripts ...] 

     </put-list-attribute> 
    </definition> 
</tiles-definition> 
関連する問題