RichFaces-メニューコンポーネント

RichFacesは、メニュータイプのマークアップを作成するために使用されるタグの幅広いバージョンを提供します。この章では、ブラウザでメニューを簡単にレンダリングできる古い機能とともに、いくつかの新しい機能について学習します。

<rich:dropDownMenu>

このタグを使用して、開発者はドロップダウンメニューを作成できます。このタグは、Webサイトのヘッダーを作成するのに役立ちます。次の例では、このタグを実際の生活で使用する方法を学習します。1つのファイルを作成し、「DropDownList.xhtml」という名前を付けます。その中に次のコードを配置します。

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head></h:head> 
   
   <h:body> 
      <h:form> 
         <rich:toolbar>   
            <rich:dropDownMenu>   
               <f:facet name = "label">   
                  <h:outputText value = "File" />   
               </f:facet>       
                  
               <rich:menuItem label = "New" />   
               <rich:menuItem label = "Open File..." />   
               <rich:menuItem label = "Close" />   
               <rich:menuItem label = "Close All" />
            </rich:dropDownMenu>   
         </rich:toolbar>   
      </h:form> 
   </h:body> 
   
</html>

上記の例では、1つのツールバーを作成し、そのツールバー内に1つのドロップダウンメニューを作成しています。ドロップダウンメニューはいくつでも作成できます。アクションベースのJS関数を挿入する場合は、属性を「action」として<menuItem>タグ内に実装できます。上記のコードは、ブラウザで次の出力を生成します。

<rich:contextMenu>

このタグは、クライアント側でイベントベースのドロップダウンを生成するのに役立ちます。自動的には機能しません。ユーザーはJSイベントを作成する必要があり、それがそれに応じて機能します。次の例では、レンダリングイメージを作成してから、ユーザーの応答に基づいてJSイベントを作成します。以下はxhtmlファイルです。

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>ContextMenu Example</title> 
   </h:head> 
    
   <h:body> 
      <h:form id = "form"> 
         <h:outputScript> 
            //<![CDATA[ 
               function resize(pic, coeff) { 
                  var w  =  Math.round(pic.width * coeff); 
                  var h  =  Math.round(pic.height * coeff); 
                  
                  if (w > 1 && h > 1 && h<1000 && w<1000) { 
                     pic.width  =  w; 
                     pic.heigth  =  h; 
                  } 
               } 
               function enlarge(element){ 
                  resize(element, 1.1); 
               } 
               function decrease(element){ 
                  resize(element, 0.9); 
               } 
            //]]> 
         </h:outputScript> 
         <h:graphicImage value = "http://www.tutorialspoint.com/images/jsf-minilogo.png" 
            id = "pic" style = "border : 5px solid #E4EAEF"/> 
         
         <rich:contextMenu target = "pic" mode = "client" showEvent = "click"> 
            <rich:menuItem label = "Zoom In" onclick = 
               "enlarge(#{rich:element('pic')});" id = "zin"/> 
            <rich:menuItem label = "Zoom Out" 
               onclick = "decrease(#{rich:element('pic')});" id = "zout"/> 
               
        </rich:contextMenu> 
      </h:form> 
   </h:body>
   
</html>

上記の例を実行して、レンダリングされた画像を選択します。次のオプション「ズームイン」と「ズームアウト」が表示されます。適切なオプションをクリックすると、必要な機能が画像に適用されます。上記のコードは、ブラウザで次の出力を生成します。

<リッチ:コンポーネントコントロール>

このコンポーネントは、RichFaces環境から他の関数​​を呼び出したいときはいつでもユーザーフレンドリーです。このタグは、JavaScriptベースのアクションクラスを呼び出すために使用されます。次の例は、このタグの使用方法を示しています。ファイルを作成し、「componentContent.xhtml」ファイルという名前を付けます。その中に次のコードを配置します。

<?xml version = "1.0" encoding = "UTF-8"?> 
<!-- 
   To change this license header, choose License Headers in Project Properties. 
   To change this template file, choose Tools | Templates 
   and open the template in the editor. 
--> 
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"   
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich"> 
   
   <h:head> 
      <title>Component Control Example</title>
      <meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/> 
   </h:head> 
    
   <h:body> 
      <h:commandButton value = "Call the popup"> 
         <rich:componentControl target = "popup" operation = "show" /> 
      </h:commandButton> 
      <rich:popupPanel id = "popup" modal = "false" autosized = "true" resizeable = "false">
         <f:facet name = "header"> 
            <h:outputText value = "Welcome mesage" /> 
         </f:facet> 
         
         <f:facet name = "controls"> 
            <h:outputLink value = "#" 
               onclick = "#{rich:component('popup')}.hide(); return false;" 
               style = "color: inherit"> 
               
               X 
            </h:outputLink> 
         </f:facet> 
         <p>Welcome to RICH FACE tutorial at tutorialspoint.com</p> 
      </rich:popupPanel> 
   </h:body>
   
</html>

上記のコードでは、ID「popup」を使用して「onclick()」関数を呼び出しています。実行すると、「ポップアップを呼び出す」というボタンが表示されます。ボタンをクリックすると、RichFacesは内部でJS関数を呼び出し、ブラウザーに次の出力を提供します。