からのイベントをクリックして、私はシンプルなオーバーレイが含まれているDOM-repatカスタム要素を持って取り扱い、私は閉じるボタンをクリックすると、このオーバーレイはこれがあるポリマーが、私は、ポリマーに新たなんだカスタム要素の子
を閉じる必要がありますしたいですカスタム要素
<link rel="import" href="../../bower_components/polymer/polymer.html">
<link rel="import" href="../../bower_components/paper-styles/typography.html">
<link rel="import" href="../overlay-layer/simple-overlay.html">
<dom-module is="feed-bdy">
<template items="{{items}}">
<style include="iron-flex iron-flex-alignment" >
:host{
--paper-button-ink-color: var(--paper-pink-a200);
--paper-button{
background-color: red !important;
color: red;
}
}
.custom{
color: red;
}
.content-bdy{
min-height: 120px;
}
.scrollable{
@apply(--layout-scroll);
max-width: 75%;
}
</style>
<div class="card-content">
<div class="ar-header">
<h3><a href="#"> [[items.fields.title]]</a></h3>
</div>
<div class="content-bdy"></div>
</div>
[[_renderHTML(items)]]
<div class="card-actions">
<paper-button class="custom" id="ar-[[items.fields.articleId]]" on-click="_openOverlay">إقراء المزيد !</paper-button>
<simple-overlay id="backdrop-[[items.fields.articleId]]" data-ar="backdrop-[[items.fields.articleId]]" with-backdrop class="layout scrollable">
[[_renderFullArticle(items)]]
<button id="dd">Close</button>
</simple-overlay>
<paper-button>
شارك
<iron-icon icon="reply"></iron-icon>
</paper-button>
</div>
</template>
<script>
Polymer({
is: 'feed-bdy',
listeners :{
'dd.click':'_closeOverlay'
},
_renderHTML: function(items) {
// firstp to get only the first pargarph to put in the home page
var ss= items.fields.body;
//console.log(this.$$(".card-content"));
var firstp = ss.substring(0,ss.search("</p>")+4);
this.$$(".content-bdy").innerHTML += firstp;
},
_renderFullArticle : function(items){
this.$$("simple-overlay").innerHTML +=items.fields.body;
},
_toggle : function(e){
var id = Polymer.dom(e).localTarget.title;
//console.log(id);
var moreInfo = document.getElementById(id);
// console.log(moreInfo);
var iconButton = Polymer.dom(e).localTarget;
iconButton.icon = moreInfo.opened ? 'hardware:keyboard-arrow-up'
: 'hardware:keyboard-arrow-down';
moreInfo.toggle();
},
_openOverlay : function(e){
//console.log('calling _openOverlay');
var id = Polymer.dom(e).localTarget.id.split('ar-')[1];
var dd = document.getElementById('backdrop-'+id);
dd.open();
},
_closeOverlay : function(e){
console.log(Polymer.dom(e));
console.log('calling _openOverlay');
var id = Polymer.dom(e).localTarget.id.split('ar-')[1];
// var dd = document.getElementById('backdrop-'+id);
/// dd.close();
}
});
</script>
</dom-module>
とのindex.htmlで
<div class="video layout horizontal around-justified wrap" >
<template is="dom-repeat" items="[[ajaxResponse]]" >
<paper-card image="[[item.fields.image]]" class="flex-auto" wide-layout$="{{wide}}">
<feed-bdy items="[[item]]"></feed-bdy>
</paper-card>
</template>
</div>
ので、[閉じる]ボタンをクリックすると_closeOverlayが解雇されなければならないと私は、あなたが見ることができるようにメッセージをコンソールしようとしましたが、何のイベントはあなただけのindex.htmlファイルの一部を示して任意のアドバイス
嫌いですが、このコードでは多くのことが起こっています。テンプレートリピートにあなたのスタイルタグがあります。 2.リスナーは、あなたが定義したようには動作しません。 3.ボタン要素にon-tap = "_ closeOverlay"イベントハンドラを追加します。 4.あなたのcard-actions要素はファーストクラスのカスタムポリマー要素になるはずです。そのためcloseOverlayでは、あなたが話しているオーバーレイをターゲットにメタデータを「アタッチ」せずにそのシンプルオーバーレイ要素を選択できます。今すぐあなたの目標は、どのオーバーレイをターゲットにするかを知る上で賢明でなければなりません。 – getbuckts
@getbucktsあなたの答えに感謝します.1-私はインデックスへのスタイルタグを削除しました。 2イベントを受け取るためにさまざまな方法を試しましたが、何もしませんでした。 on-tapハンドラを追加しない3イベント 4-私は本当に何が問題なのか分かりませんでした – user3853257