KnockoutJS-テンプレート

Template繰り返し使用できるDOM要素のセットです。テンプレートを使用すると、DOM要素の重複を最小限に抑えることができるため、複雑なアプリケーションを簡単に構築できます。

テンプレートを作成する方法は2つあります。

  • Native templating−このメソッドは、foreach、with、ifなどの制御フローバインディングをサポートします。これらのバインディングは、要素に存在するHTMLマークアップをキャプチャし、ランダムなアイテムのテンプレートとして使用します。このテンプレートには外部ライブラリは必要ありません。

  • String-based templating− KOはサードパーティエンジンに接続してViewModel値を渡し、結果のマークアップをドキュメントに挿入します。たとえば、JQuery.tmplやUnderscoreEngineなどです。

Syntax

template: <parameter-value>

<script type = "text/html" id = "template-name">
   ...
   ...   // DOM elemets to be processed
   ...
</script>

ご了承ください type として提供されます text/html KOに通知するスクリプトブロックでは、実行可能ブロックではなく、レンダリングする必要がある単なるテンプレートブロックです。

Parameters

以下のプロパティの組み合わせをパラメータ値としてテンプレートに送信できます。

  • name −これはテンプレートの名前を表します。

  • nodes−これは、テンプレートとして使用されるDOMノードの配列を表します。nameパラメーターが渡された場合、このパラメーターは無視されます。

  • data −これはテンプレートを介して表示されるデータに他なりません。

  • if −指定された条件がtrueまたはtrueのような値になる場合、テンプレートが提供されます。

  • foreach −foreach形式でテンプレートを提供する。

  • as −これは、foreach要素にエイリアスを作成するためだけのものです。

  • afterAdd, afterRender, beforeRemove −これらはすべて、実行される操作に応じて実行される呼び出し可能な関数を表します。

観察

名前付きテンプレートのレンダリング

テンプレートは、制御フローバインディングとともに使用される場合、DOM内のHTMLマークアップによって暗黙的に定義されます。ただし、必要に応じて、テンプレートを別の要素に分解し、名前で参照することができます。

Example

<!DOCTYPE html>
   <head>
      <title>KnockoutJS Templating - Named Template</title>
      <script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.3.0.js"
         type = "text/javascript"></script>
   </head>

   <body>
      <h2>Friends List</h2>
      Here are the Friends from your contact page:
      <div data-bind = "template: { name: 'friend-template', data: friend1 }"></div>
      <div data-bind = "template: { name: 'friend-template', data: friend2 }"></div>

      <script type = "text/html" id = "friend-template">
         <h3 data-bind = "text: name"></h3>
         <p>Contact Number: <span data-bind = "text: contactNumber"></span></p>
         <p>Email-id: <span data-bind = "text: email"></span></p>
      </script>

      <script type = "text/javascript">
         function MyViewModel() {
            this.friend1 = { 
               name: 'Smith', 
               contactNumber: 4556750345, 
               email: '[email protected]' 
            };
            
            this.friend2 = { 
               name: 'Jack', 
               contactNumber: 6789358001, 
               email: '[email protected]' 
            };
         }

         var vm = new MyViewModel();
         ko.applyBindings(vm);
      </script>
      
   </body>
</html>

Output

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のコードをに保存します template-named.htm ファイル。

  • このHTMLファイルをブラウザで開きます。

  • ここでは、friend-templateが2回使用されています。

テンプレートで「foreach」を使用する

以下は使用例です foreach テンプレート名と一緒にパラメータ。

Example

<!DOCTYPE html>
   <head>
      <title>KnockoutJS Templating - foreach used with Template</title>
      <script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.3.0.js"
         type = "text/javascript"></script>
   </head>

   <body>
      <h2>Friends List</h2>
      Here are the Friends from your contact page:
      <div data-bind = "template: { name: 'friend-template', foreach: friends }"></div>

      <script type = "text/html" id = "friend-template">
         <h3 data-bind = "text: name"></h3>
         <p>Contact Number: <span data-bind = "text: contactNumber"></span></p>
         <p>Email-id: <span data-bind = "text: email"></span></p>
      </script>

      <script type = "text/javascript">
         function MyViewModel() {
            this.friends = [
               { name: 'Smith', contactNumber: 4556750345, email: '[email protected]' },
               { name: 'Jack', contactNumber: 6789358001, email: '[email protected]' },
               { name: 'Lisa', contactNumber: 4567893131, email: '[email protected]' }
            ]
         }

         var vm = new MyViewModel();
         ko.applyBindings(vm);
      </script>
      
   </body>
</html>

Output

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のコードをに保存します template-foreach.htm ファイル。

  • このHTMLファイルをブラウザで開きます。

  • ここでは、foreachコントロールがテンプレートバインディングで使用されています。

foreachアイテムのキーワードとして使用するエイリアスの作成

以下は、foreachアイテムのエイリアスを作成する方法です-

<div data-bind = "template: { 
   name: 'friend-template', 
   foreach: friends, 
   as: 'frnz' 
}"></div>

エイリアスを作成することで、foreachループ内から親オブジェクトを簡単に参照できるようになります。この機能は、コードが複雑で複数のレベルにネストされている場合に役立ちます。

Example

<!DOCTYPE html>
   <head>
      <title>KnockoutJS Templating - using alias in Template</title>
      <script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.3.0.js"
         type = "text/javascript"></script>
   </head>

   <body>
      <h2>Friends List</h2>
      Here are the Friends from your contact page:
      <ul data-bind = "template: { 
         name: 'friend-template', 
         foreach: friends, 
         as: 'frnz' 
      }"></ul>

      <script type = "text/html" id = "friend-template">
         <li>
            <h3 data-bind = "text: name"></h3>
            <span>Contact Numbers</span>
            <ul data-bind = "template: { 
               name : 'contacts-template', 
               foreach:contactNumber, 
               as: 'cont'
            } "></ul>
            <p>Email-id: <span data-bind = "text: email"></span></p>
         </li>
      </script>

      <script type = "text/html" id = "contacts-template">
         <li>
            <p><span data-bind = "text: cont"></span></p>
         </li>
      </script>

      <script type = "text/javascript">
         function MyViewModel() {
            this.friends = ko.observableArray ( [
               { 
                  name: 'Smith', 
                  contactNumber: [ 4556750345, 4356787934 ], 
                  email: '[email protected]' 
               },
               
               { 
                  name: 'Jack', 
                  contactNumber: [ 6789358001, 3456895445 ], 
                  email: '[email protected]' 
               },
               
               { 
                  name: 'Lisa', 
                  contactNumber: [ 4567893131, 9876456783, 1349873445 ],  
                  email: '[email protected]' 
               }
            ]);
         }

         var vm = new MyViewModel();
         ko.applyBindings(vm);
      </script>
      
   </body>
</html>

Output

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のコードをに保存します template-as-alias.htm ファイル。

  • このHTMLファイルをブラウザで開きます。

  • アレイのフルネームの代わりにエイリアスが使用されます。

afterAdd、beforeRemove、およびafterRenderの使用

テンプレートによって作成されたDOM要素に対して追加のカスタムロジックを実行する必要がある場合があります。このような場合、以下のコールバックを使用できます。次に、foreach要素を使用していると考えてください。

afterAdd −この関数は、foreachに記載されている配列に新しい項目が追加されたときに呼び出されます。

beforeRemove −この関数は、foreachに記載されている配列からアイテムを削除する直前に呼び出されます。

afterRender −ここで説明する関数は、foreachがレンダリングされ、新しいエントリが配列に追加されるたびに呼び出されます。

Example

<!DOCTYPE html>
   <head>
      <title>KnockoutJS Templating - Use of afterRender Template</title>
      <script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.3.0.js"
         type = "text/javascript"></script>
      <script src = "https://code.jquery.com/jquery-2.1.3.min.js"
         type = "text/javascript"></script>
   </head>

   <body>
      <h2>Friends List</h2>
      Here are the Friends from your contact page:
      <div data-bind = "template: { 
         name: 'friend-template', 
         foreach: friends , 
         afterRender: afterProcess
      }"></div>

      <script type = "text/html" id = "friend-template">
         <h3 data-bind = "text: name"></h3>
         <p>Contact Number: <span data-bind = "text: contactNumber"></span></p>
         <p>Email-id: <span data-bind = "text: email"></span></p>
         <button data-bind = "click: $root.removeContact">remove </button>
      </script>

      <script type = "text/javascript">
         function MyViewModel() {
            self = this;
            this.friends = ko.observableArray ([
               { name: 'Smith', contactNumber: 4556750345, email: '[email protected]' },
               { name: 'Jack', contactNumber: 6789358001, email: '[email protected]' },
            ])

            this.afterProcess = function(elements, data){
               $(elements).css({color: 'magenta' });
            }

            self.removeContact = function() {
               self.friends.remove(this);
            }
         }

         var vm = new MyViewModel();
         ko.applyBindings(vm);
      </script>
   </body>
</html>

Output

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のコードをに保存します template-afterrender.htm ファイル。

  • このHTMLファイルをブラウザで開きます。

  • ここでは、foreachがレンダリングされるたびにafterProcess関数が実行されます。

テンプレートを動的に選択する

使用可能なテンプレートが複数ある場合は、名前を次のようにすることで動的に1つを選択できます。 observableパラメータ。したがって、名前パラメータが変更されるとテンプレート値が再評価され、データが再レンダリングされます。

Example

<!DOCTYPE html>
   <head>
      <title>KnockoutJS Templating - Dynamic Template</title>
      <script src = "https://ajax.aspnetcdn.com/ajax/knockout/knockout-3.3.0.js"
         type = "text/javascript"></script>
   </head>
   
   <body>
      <h2>Friends List</h2>
      Here are the Friends from your contact page:
      <div data-bind = "template: { 
         name: whichTemplate, 
         foreach: friends 
      }"></div>

      <script type = "text/html" id = "only-phon">
         <h3 data-bind = "text: name"></h3>
         <p>Contact Number: <span data-bind = "text: contactNumber"></span></p>
      </script>

      <script type = "text/html" id = "only-email">
         <h3 data-bind = "text: name"></h3>
         <p>Email-id: <span data-bind = "text: email"></span></p>
      </script>

      <script type = "text/javascript">
         function MyViewModel() {
   
            this.friends = ko.observableArray ([
               {
                  name: 'Smith', 
                  contactNumber: 4556750345, 
                  email: '[email protected]', 
                  active: ko.observable(true)
               },
               
               {
                  name: 'Jack', 
                  contactNumber: 6789358001, 
                  email: '[email protected]', 
                  active: ko.observable(false)
               },
            ]);

            this.whichTemplate = function(friends) {
               return friends.active() ? "only-phon" : "only-email";
            }
         }

         var vm = new MyViewModel();
         ko.applyBindings(vm);
      </script>
      
   </body>
</html>

Output

上記のコードがどのように機能するかを確認するために、次の手順を実行してみましょう-

  • 上記のコードをに保存します template-dynamic.htm ファイル。

  • このHTMLファイルをブラウザで開きます。

  • 使用するテンプレートは、アクティブなフラグ値に応じて決定されます。

外部文字列ベースのエンジンの使用

ネイティブテンプレートは、ネストされたコードブロックでも、さまざまな制御フロー要素で完全に機能します。KOは、UnderscoreテンプレートエンジンやJQuery.tmplなどの外部テンプレートライブラリと統合する方法も提供します。

公式サイトで述べたように、JQuery.tmplは2011年12月以降、活発に開発されていません。したがって、KOのネイティブテンプレートは、JQuery.tmplやその他の文字列ベースのテンプレートエンジンの代わりにのみ推奨されます。

詳しくは公式サイトをご覧ください。