Polymer 3 + Webpack -> PolymerElement不能在没有使用'new'的情况下被调用

3

我正在测试 Polymer 3.0 预览代码,并希望使用 Webpack 和 Babel 设置一个简单的项目,将其转换回 ES5。

编译工作正常。我在演示页面中添加了 custom-elements-es5-adapter.js,但捆绑的代码执行时出现以下错误:

custom-component.js:13 Uncaught TypeError: Class constructor PolymerElement cannot be invoked without 'new'
    at HTMLElement.CustomComponent (custom-component.js:13)
    at new j (custom-elements-es5-adapter.js:4)
    at CustomElementRegistry.value (custom-elements-es5-adapter.js:4)
    at Object.defineProperty.value (custom-component.js:23)
    at __webpack_require__ (bootstrap 6c5b87648fe743e36ebc:19)
    at window.JSCompiler_renameProperty (bootstrap 6c5b87648fe743e36ebc:62)
    at bootstrap 6c5b87648fe743e36ebc:62

以下是取自此处的ES6代码:https://www.polymer-project.org/blog/2017-08-23-hands-on-30-preview

import {Element as PolymerElement} from '@polymer/polymer/polymer-element';

export class CustomComponent extends PolymerElement {
    static get template() {
        return `<div>This is my [[name]] app.</div>`
    }

    constructor() {
        super();
        this.name = '3.0 preview';
    }

    static get properties() {
        name: {
            Type: String
        }
    }
}

customElements.define('custom-component', CustomComponent);

webpack.config.js

const {resolve} = require('path');

module.exports = {
    context: resolve(__dirname, 'src'),
    entry: {
        "custom-component": './custom-component.js'
    },
    output: {
        filename: '[name].js',
        path: resolve(__dirname, 'dist'),
    },
    resolve: {
        extensions: ['.js']
    },
    devtool: 'source-map',
    module: {
        rules: [
            {
                test: /\.js$/,
                exclude: /(node_modules|bower_components)/,
                use: {
                    loader: 'babel-loader',
                    options: {
                        presets: ['@babel/preset-env']
                    }
                }
            }
        ]
    }
};

您可以在我的Github Repo中找到代码来进行快速审查:https://github.com/janrembold/webcomponent-examples/tree/master/06-frameworks/04-polymer 这个错误是不是只因为Polymer3处于早期状态,还是我在这里漏掉了什么?
顺便说一下,我不想使用polymer-cli,因为我们的项目有一些特殊要求。
非常感谢您提供的任何帮助!
1个回答

2
我遇到了同样的问题: 我通过使用来解决这个问题,该插件支持原生自定义元素(Safari和Chrome浏览器)。 对于转译,我使用了。
不进行转译: plugins: ['syntax-dynamic-import'] 进行转译: plugins: ['dynamic-import-webpack']

你的webpack加载器配置是什么样子的?我还是收到了错误信息。 - Yairopro
你能给我展示一下你的webpack.js文件和错误信息吗? - rickdehoop

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接