Polymer 1.7Штамповочный шаблон Async? Вопрос о расе
Является ли штамп шаблоном асинхронной операции? Это не I/O, поэтому я не знаю, почему это было бы. Однако здесь есть состояние гонки, где this.$$('#uploadedImage1')
не определено. Он работает, если я использую <div hidden="[[foo]]">
вместо template is="dom-if"
, так что я знаю, что это состояние гонки.
<template is="dom-if" if="[[uploadedImage1]]">
<div id="uploadedImage1" class="row-image horizontal layout">
</div>
</template>
...
ready: function(e) {
function readURL(e) {
var el = e.target.id
var uploadedID = e.target.dataset.uploaded;
var file = Polymer.dom(e).localTarget.files[0];
var reader = new FileReader();
reader.onloadend =()=> {
this[uploadedID] = true;
//RACE CONDITION HERE
this.$$('#uploadedImage1').style.backgroundImage = `url(${reader.result})`;
}
reader.readAsDataURL(file);
}
this.$['images-container'].addEventListener('change', readURL.bind(this), false)
}
помогает очень, спасибо! – dman