2

カスタム要素を使用して試しています。JS を使用して要素を作成し、それらを DOM に追加したいと考えています。基本的なhtmlページでこれをすべて1つのファイルで使用すると、すべて正常に動作します。

'use strict';
class FlashCard extends HTMLElement {
constructor(cardSet) {
    super();
    this.cardSet = cardSet;
    this.cardNumber = 0;
}
connectedCallback() {
    this.id = 'flashcard';
    this.style.cursor = 'pointer';
    this.render(this.cardSet);
    this.addEventListener('click', this.onClick);
}

render() {
    this.innerHTML = this.cardSet[this.cardNumber];
}

onClick() {
    let deckSize = this.cardSet.length;
    if (this.cardNumber === deckSize-1) {
        this.cardNumber = 0;
    } else {
        this.cardNumber++;
    };
    this.render();
}
}
customElements.define('flash-card', FlashCard);
document.addEventListener('DOMContentLoaded', function() {
let card = new FlashCard(['a', 'b', 'c', 'd']);
document.getElementsByTagName('body')[0].appendChild(card);
});

コードを別々のファイルに分割しようとすると、問題が発生します。

'use strict';
export default class FlashCard extends HTMLElement {
    constructor(cardSet) {
        super();
        this.cardSet = cardSet;
        this.cardNumber = 0;
    }
    connectedCallback() {
        this.id = 'flashcard';
        this.style.cursor = 'pointer';
        this.render(this.cardSet);
        this.addEventListener('click', this.onClick);
    }

    render() {
        this.innerHTML = this.cardSet[this.cardNumber];
    }

    onClick() {
        let deckSize = this.cardSet.length;
        if (this.cardNumber === deckSize-1) {
            this.cardNumber = 0;
        } else {
            this.cardNumber++;
        };
        this.render();
    }
}
customElements.define('flash-card', FlashCard);

そして、別のファイルで

import FlashCard from './flashcard';

    document.addEventListener('DOMContentLoaded', function() {
    let card = new FlashCard(['a', 'b', 'c', 'd']);
document.getElementsByTagName('body')[0].appendChild(card);
});

次に、package.json ファイルで npm スクリプトを使用してエクスポート/インポートするため、javascript をトランスパイルします。

"watch": "watchify elements/*.js -t babelify --plugins transform-es2015-classes 
-o js/bundle.js --debug --verbose",

Chrome 55で発生するエラーは

Failed to construct 'HTMLElement': Please use the 'new' 
operator, this DOM object constructor cannot be called as a function.

したがって、トランスパイルされたコードは HTMLElement オブジェクトのコンストラクター メソッドを呼び出そうとしていますが、この場合、メソッドは関数ではありません。

私の質問は、上記のようにコードを個別のファイルに分割する方法ですが、トランスパイラーが正しく解釈できる方法でしょうか?

4

1 に答える 1

2

constructor() メソッドでは、super() の代わりに Reflect.construct() を使用するようにしてください。

var self = Reflect.construct( HTMLElement, [], Flashcard )
self.cardSet = cardSet
...
return self

また、問題を解決するはずのこのプラグインを試すこともできます (私はテストしていません)。

于 2016-12-30T12:24:25.707 に答える