0

我过去曾使用一种方法将paper-inputs 设为空白,但是我通常的方法在与 . 结合使用时不起作用Vaadin-grid

我在这里错过了什么吗?

Vaadin 网格 HTML

<vaadin-grid-column>
    <template class="header">
        <div class="horizontal layout cell">
            <label for="keyFilter" class="keyText cell flex">Key</label>
            <vaadin-grid-filter class="cell" id="keyFilter" path="key" value="[[_filterKey]]">
                  <paper-input no-float-label class="keyFilter" id="keyFilter" slot="filter" placeholder="Filter search" value="{{_filterKey::input}}" focus-target on-input="clearAppear" >
                        <iron-icon suffix icon="clear" class="clearIcon" on-click="clearField" clear-item-id="keyFilter"></iron-icon>
                 </paper-input>
             </vaadin-grid-filter>
        </div>
    </template>
    <template class="cell">[[item.key]]</template>
</vaadin-grid-column>

我尝试了以下JS:

// Attempt 1 - gives "undefined" within the dev tools 
this.$.keyFilter.value = '';

// Attempt 2 - finds the correct element, but does not set the value to blank
document.getElementById('keyFilter').value = ''
4

1 回答 1

1

要在元素的 shadow DOM 中定位动态创建的节点,请使用标准 DOMquerySelector方法:

this.shadowRoot.querySelector(selector)

所以,对于你的问题使用this.shadowRoot.querySelector("#keyFilter").value='';

而且您在上面的代码中犯了一个简单的错误,即为和元素提供相同id的名称 。请确保在尝试上述代码之前更改此设置。vaadin-grid-filterpaper-input

于 2017-08-22T12:21:17.477 回答