コメントに基づいて、アセットをロードする他のすべてのHTMLElementが行うことを実行する必要があります。コンストラクターにサイドローディングアクションを開始させ、結果に応じてロードまたはエラーイベントを生成します。
はい、それはプロミスを使用することを意味しますが、「他のすべてのHTML要素と同じように物事を行う」ことも意味するので、あなたは良い仲間です。例えば:
var img = new Image();
img.onload = function(evt) { ... }
img.addEventListener("load", evt => ... );
img.onerror = function(evt) { ... }
img.addEventListener("error", evt => ... );
img.src = "some url";
これにより、ソースアセットの非同期ロードが開始され、成功すると終了し、失敗するonload
とで終了しonerror
ます。だから、あなた自身のクラスにもこれをさせる:
class EMailElement extends HTMLElement {
constructor() {
super();
this.uid = this.getAttribute('data-uid');
}
setAttribute(name, value) {
super.setAttribute(name, value);
if (name === 'data-uid') {
this.uid = value;
}
}
set uid(input) {
if (!input) return;
const uid = parseInt(input);
// don't fight the river, go with the flow
let getEmail = new Promise( (resolve, reject) => {
yourDataBase.getByUID(uid, (err, result) => {
if (err) return reject(err);
resolve(result);
});
});
// kick off the promise, which will be async all on its own
getEmail()
.then(result => {
this.renderLoaded(result.message);
})
.catch(error => {
this.renderError(error);
});
}
};
customElements.define('e-mail', EmailElement);
そして、あなたはrenderLoaded / renderError関数がイベント呼び出しとシャドウdomを処理するようにします:
renderLoaded(message) {
const shadowRoot = this.attachShadow({mode: 'open'});
shadowRoot.innerHTML = `
<div class="email">A random email message has appeared. ${message}</div>
`;
// is there an ancient event listener?
if (this.onload) {
this.onload(...);
}
// there might be modern event listeners. dispatch an event.
this.dispatchEvent(new Event('load', ...));
}
renderFailed() {
const shadowRoot = this.attachShadow({mode: 'open'});
shadowRoot.innerHTML = `
<div class="email">No email messages.</div>
`;
// is there an ancient event listener?
if (this.onload) {
this.onerror(...);
}
// there might be modern event listeners. dispatch an event.
this.dispatchEvent(new Event('error', ...));
}
また、私はあなたを変え注意id
にclass
あなたにいくつかの奇妙なコードを書いていない限りしかあなたの単一のインスタンスできるため、<e-mail>
ページ上の要素は、あなたがユニークな識別子を使用して、要素の束にそれを割り当てることはできません。