Я пытаюсь получить обновленные данные в дочернем элементе Polymer, но данные остаются привязанными к инициализированному значению.
PARENT
<template is="dom-if" if="[[items.0]]">
<child-el id="id_0" id-item="[[items.0.idItem]]"></child-el>
</template>
...
_updateChild () {
if (this.items[0]) {
this.shadowRoot.getElementById('id_0').idItem = this.items[0].idItem;
this.shadowRoot.getElementById('id_0').idItem.notifyPath;
}
}
CHILD
<iron-ajax id="ajax"
handle-as="json"
last-response="{{data}}"
method="get"
on-error="_onError"
url="https://api.com/item-price">
</iron-ajax>
<div>
<p id="price">[[price(data.price)]]</p>
</div>
...
static get properties() {
return {
idItem: { type: String, observer: 'getResponse' }
}
}
getResponse() {
let request = this.$.ajax.generateRequest();
request.completes.then(req => {
this.idItem = null;
})
}
price(amt) {
return amt
}
Обновление цены выполняется, но когда установлен idItem
, но наблюдатель на idItem
"getResponse()
" не выполняется и привязывается к data.price
.
Как правильно настроить эти события, чтобы каждый раз, когда items.0.idItem
изменял привязку к child-eel
this.data.price
, обновлялся?