Polymer2.0- Многократное разрушение железа с использованием класса

Я пытаюсь добиться множественного коллапса железа, используя класс вместо идентификатора

Решение, упомянутое в вопросе - Polymer Multiple Iron-Collapse работает, но у меня больше железных коллапсов, которые я не хочу создавать дублирующий код для той же функциональности

Я пробовал разные варианты, пытаясь выбрать соответствующий элемент, используя класс вместо идентификатора

codepen- https://codepen.io/nagasai/pen/YxyqmE

HTML:

<head>
  <base href="https://polygit.org/polymer+v2.0.0/shadycss+webcomponents+1.0.0/components/">
  <link rel="import" href="polymer/polymer.html">
  <link rel="import" href="iron-collapse/iron-collapse.html">
   <link rel="import" href="paper-input/paper-input.html">
</head>
<body>

  <x-foo attr="{{text}}"></x-foo>

  <dom-module id="x-foo">
    <template id="collapse1">


<button on-click="toggle">toggle collapse</button>
<iron-collapse class="collapse">
  <div>Enter text collapse1</div>
</iron-collapse>


<button on-click="toggle">toggle collapse</button>
<iron-collapse class="collapse">
  <div>Enter text collapse2</div>
</iron-collapse>


 <button on-click="toggle">toggle collapse</button>
<iron-collapse class="collapse">
  <div>Enter text collapse2</div>
</iron-collapse>

    </template>
  </dom-module>
</body>

JS:

  class XFoo extends Polymer.Element {
    static get is() { return 'x-foo'; }

    static get properties() {
      return {};

    }
       toggle() {
         console.log(this);
  this.$.querySelector('.collapse').toggle();
}

  }
  customElements.define(XFoo.is, XFoo);

2 ответа

Решение

Я предлагаю вам использовать пользовательский атрибут. Вот рабочее решение: https://codepen.io/Sahero/pen/VzeWNd

HTML:

<head>
   <base href="https://polygit.org/polymer+v2.0.0/shadycss+webcomponents+1.0.0/components/">
   <link rel="import" href="polymer/polymer.html">
   <link rel="import" href="iron-collapse/iron-collapse.html">
   <link rel="import" href="paper-input/paper-input.html">
</head>
<body>     
  <x-foo attr="{{text}}"></x-foo>

  <dom-module id="x-foo">
    <template>      
      <button on-click="toggle" my-attribute="collapse1">toggle 
      collapse</button>
      <iron-collapse id="collapse1" class="collapse">
        <div>Enter text collapse1</div>
      </iron-collapse>   

      <button on-click="toggle" my-attribute="collapse2">toggle 
      collapse</button>
      <iron-collapse id="collapse2" class="collapse">
      <div>Enter text collapse2</div>
      </iron-collapse>

      <button on-click="toggle" my-attribute="collapse3">toggle 
      collapse</button>
      <iron-collapse id="collapse3" class="collapse">
      <div>Enter text collapse3</div>
      </iron-collapse>

    </template>
  </dom-module>
</body>

JS:

  class XFoo extends Polymer.Element {
    static get is() { return 'x-foo'; }

    static get properties() {
      return {};

    }
   toggle(e) {
     //console.log(this);
     var id = e.target.getAttribute('my-attribute');
     console.log(id);
     this.shadowRoot.querySelector('#'+id).toggle();
     //this.shadowRoot.querySelector('.collapse').toggle();
  }

  }
  customElements.define(XFoo.is, XFoo);

Способ добиться этого для <dom-repeat> предметы использовать события currentTarget так что вы можете выбрать элемент, где метод был вызван. У меня есть пример, где у вас есть несколько элементов списка (paper-listbox) со значком стрелки вправо, который меняется на стрелку вниз, когда iron-collapse пункт расширен. В моем примере класс не нужен, но вы могли бы так же легко e.currentTarget.querySelector('.theClass')

Пример:

<dom-repeat items={{list}}>
    <template>
        <paper-listbox on-click="toggle">
            <iron-icon id="icon" icon="icons:chevron-right"></iron-icon>
            <paper-item>{{item.title}}</paper-item>
            <iron-collapse class="collapse">
                <p>Content here . . . </p>
            </iron-collapse>
        </paper-listbox>
    </template>
</dom-repeat>

и JS под ним:

toggle(e) {
    // currentTarget selects the paper-listbox where the toggle method occurred.
    var collapseArea = e.currentTarget.querySelector('iron-collapse');
    var theIcon = e.currentTarget.querySelector('iron-icon');
    collapseArea.toggle();
    // toggle the icon for list item from right arrow to downward arrow
    (theIcon.getAttribute('icon') === 'icons:chevron-right') ? theIcon.setAttribute('icon', 'icons:expand-more') : theIcon.setAttribute('icon', 'icons:chevron-right');
}
Другие вопросы по тегам