2014年6月26日木曜日

polymer メモ



■ 外部の element を使うには、import し、

<link rel="import" href="../components/core-header-panel/core-header-panel.html">

element をタグとして使う

<core-header-panel>
...
</core-header-panel>



■ 自分で element を作ることもできる

element を作るには、<polymer-element> を使って定義する

Shadow DOM (<template>)で他の element をカプセル化できる
ここで指定したスタイルはこのマークアップにだけ提供され、他のところに影響しない
Shadow DOM polyfill docs

公開されたプロパティ(この例だと "counter")はマークアップから初期化でき、値が変更されたときは変更のハンドラーが呼ばれる

{{ }} でプロパティを直接マークアップにバンドルできる

element の定義で on-[event](この例だと on-tap)属性を使ってイベントハンドラを function にバンドルできる

template の子は id 属性の値を使って、this.$.[id] で参照できる(この例だと this.$.counterVal)

  1. <polymer-element name="my-counter" attributes="counter">  
  2.   <template>  
  3.     <style> /*...*/ </style>  
  4.     <div id="label"><content></content></div>  
  5.     Value: <span id="counterVal">{{counter}}</span>  
  6.     <button on-tap="{{increment}}">Increment</button>  
  7.   </template>  
  8.   <script>  
  9.     Polymer({  
  10.       counter: 0, // Default value  
  11.       counterChanged: function() {  
  12.         this.$.counterVal.classList.add('highlight');  
  13.       },  
  14.       increment: function() {  
  15.         this.counter++;  
  16.       }  
  17.     });  
  18.   </script>  
  19. </polymer-element>  


作った element をタグとして使う

<my-counter counter="10">Points</my-counter>



■ body unresolved
  1. <body unresolved>  
  2. ...  
  3. </body>  
<body> の unresolved 属性は、カスタムエレメントのネイティブサポートが足りないブラウザでの flash of unstyled content (FOUC) を防ぐのに使われる

■ Tabの基本構成
  1. <core-header-panel>  
  2.   
  3.   <core-toolbar>  
  4.   
  5.     <paper-tabs valueattr="name" selected="all" self-end>  
  6.       <paper-tab name="all">ALL</paper-tab>  
  7.       <paper-tab name="favorites">FAVORITES</paper-tab>  
  8.     </paper-tabs>  
  9.   
  10.   </core-toolbar>  
  11.   
  12.   <!-- main page content will go here -->  
  13.   
  14. </core-header-panel>  
<paper-tab ...><img src="ic_all.png"></paper-tab> のように画像もOK



■ 独自 element を1つの html ファイルにする

- 必要な element の import + <polymer-element>
- polymer-element の name 属性値をファイル名に使う(must じゃないが、そのほうがわかりやすい)
- 最後に Polymer({}); を呼んで element を登録する。これによりブラウザに認識される

post-card.html
  1. <link rel="import" href="../components/polymer/polymer.html">  
  2. <link rel="import" href="../components/core-icon-button/core-icon-button.html">  
  3.   
  4. <polymer-element name="post-card">  
  5.   <template>  
  6.     ...  
  7.       
  8.   </template>  
  9.   <script>  
  10.    Polymer({});  
  11.   </script>  
  12. </polymer-element>  
Shadow DOM 内での :host pseudo-class は、独自 element 自身をさすことになる(上のコードだと <post-card> のスタイルを指定することになる)
  1. <template>  
  2.   <style>  
  3.   :host {  
  4.    ...  
  5.   }  
  6.   </style>  
  7.   ...  
  8. </template>  




■ 独自 element の子 element
  1. <post-card>  
  2.   <h2>hoge</h2>  
  3. </post-card>  
のように、独自 element に子 element を入れる場合、insertion point を指定しないと描画されない

insertion point は <content> で作成する
  1. <polymer-element name="post-card">  
  2.   <template>  
  3.     <style>  
  4.     ...  
  5.     </style>  
  6.   
  7.     <div class="card-header" layout horizontal center>  
  8.       <content select="img"></content>  
  9.       <content select="h2"></content>  
  10.     </div>  
  11.     <content></content>  
  12.       
  13.   </template>  
  14.   ...  
  15. </polymer-element>  
この場合、<post-card> 内の <img> は最初の content に挿入され、 <h2> は2番目の content に挿入され、 それ以外の子 element は最後の content に挿入される

子 element のスタイルには ::content pseudo element を使う
  1. <polymer-element name="post-card">  
  2.   <template>  
  3.     <style>  
  4.     ...  
  5.   
  6.     polyfill-next-selector { content: ".card-header h2";}  
  7.     .card-header ::content h2 {  
  8.       margin: 0;  
  9.       font-size: 1.8rem;  
  10.       font-weight: 300;  
  11.     }  
  12.     polyfill-next-selector { content: ".card-header img";}  
  13.     .card-header ::content img {  
  14.       width: 70px;  
  15.       border-radius: 50%;  
  16.       margin: 10px;  
  17.     }  
  18.     </style>  
  19.     ...  
  20.   </template>  
  21.   ...  
  22. </polymer-element>  
Shadow DOM をネイティブにサポートしていないブラウザのために、 polyfill-next-selector を使って、::content ルールを non-shadow DOM ルールにどのように変換するかを指定する



0 件のコメント:

コメントを投稿