与普通的ES6文件一样,如何从babel和webpack生成的文件中导入类?

问题描述

事实是我一直在努力理解,为什么我不能从以前使用 babel webpack 生成文件中导入类,所以我想向您展示我的结论以及我的困惑。

这是我的结构文件

test
-dist
 -test.js
-public
 -index.html
 -main.js
-src
 -test.js
-package.json
-webpack

所以,如果我这样做

index.html

<!DOCTYPE html>
<html>
<body>
   <script src="./main.js" type="module"></script>
</body>
</html>

test.js

export default class Person {
    constructor() {
        this.name = "Jon Doe";
    }
    getName() {
        return this.name;
    }
}

main.js

import getName from "../src/test.js";

let person = new Person();
console.log(person.getName());

输出

琼·多伊

到目前为止,使用ES6类导入和导出,一切都能按预期进行

然后,我使用 babel webpack ,我将执行以下操作。

package.json

{
  "name": "test","scripts": {
    "build": "webpack"
  },"author": "shimozurdo","devDependencies": {
    "@babel/core": "^7.11.6","@babel/preset-env": "^7.11.5","webpack": "^4.44.1","webpack-cli": "^3.3.12","babel-loader": "^8.1.0"
  }
}

webpack.config

const path = require('path');

module.exports = {
    mode: 'development',entry: {
        "test": './src/test.js',},output: {
        path: path.resolve(__dirname,'dist'),filename: '[name].js',library: 'testObj',libraryTarget: 'umd',umdNamedDefine: true
    },module: {
        rules: [
            {
                test: /\.js$/,exclude: /node_modules/,loader: "babel-loader",options: {
                    "presets": ["@babel/preset-env"]
                }
            }
        ]
    }
};

然后我使用npm run build

index.html

<!DOCTYPE html>
<html>
<body>
    <script src="../dist/test.js"></script>
    <script src="./main.js"></script>
</body>
</html>

test.js

(function webpackUniversalModuleDeFinition(root,factory) {
    if(typeof exports === 'object' && typeof module === 'object')
        module.exports = factory();
    else if(typeof define === 'function' && define.amd)
        define("testObj",[],factory);
    else if(typeof exports === 'object')
        exports["testObj"] = factory();
    else
        root["testObj"] = factory();
})(window,function() {
return /******/ (function(modules) { // webpackBootstrap
/******/    // The module cache
/******/    var installedModules = {};
/******/
/******/    // The require function
/******/    function __webpack_require__(moduleId) {
/******/
/******/        // Check if module is in cache
/******/        if(installedModules[moduleId]) {
/******/            return installedModules[moduleId].exports;
/******/        }
/******/        // Create a new module (and put it into the cache)
/******/        var module = installedModules[moduleId] = {
/******/            i: moduleId,/******/            l: false,/******/            exports: {}
/******/        };
/******/
/******/        // Execute the module function
/******/        modules[moduleId].call(module.exports,module,module.exports,__webpack_require__);
/******/
/******/        // Flag the module as loaded
/******/        module.l = true;
/******/
/******/        // Return the exports of the module
/******/        return module.exports;
/******/    }
/******/
/******/
/******/    // expose the modules object (__webpack_modules__)
/******/    __webpack_require__.m = modules;
/******/
/******/    // expose the module cache
/******/    __webpack_require__.c = installedModules;
/******/
/******/    // define getter function for harmony exports
/******/    __webpack_require__.d = function(exports,name,getter) {
/******/        if(!__webpack_require__.o(exports,name)) {
/******/            Object.defineProperty(exports,{ enumerable: true,get: getter });
/******/        }
/******/    };
/******/
/******/    // define __esModule on exports
/******/    __webpack_require__.r = function(exports) {
/******/        if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/            Object.defineProperty(exports,Symbol.toStringTag,{ value: 'Module' });
/******/        }
/******/        Object.defineProperty(exports,'__esModule',{ value: true });
/******/    };
/******/
/******/    // create a fake namespace object
/******/    // mode & 1: value is a module id,require it
/******/    // mode & 2: merge all properties of value into the ns
/******/    // mode & 4: return value when already ns object
/******/    // mode & 8|1: behave like require
/******/    __webpack_require__.t = function(value,mode) {
/******/        if(mode & 1) value = __webpack_require__(value);
/******/        if(mode & 8) return value;
/******/        if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/        var ns = Object.create(null);
/******/        __webpack_require__.r(ns);
/******/        Object.defineProperty(ns,'default',value: value });
/******/        if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns,key,function(key) { return value[key]; }.bind(null,key));
/******/        return ns;
/******/    };
/******/
/******/    // getDefaultExport function for compatibility with non-harmony modules
/******/    __webpack_require__.n = function(module) {
/******/        var getter = module && module.__esModule ?
/******/            function getDefault() { return module['default']; } :
/******/            function getModuleExports() { return module; };
/******/        __webpack_require__.d(getter,'a',getter);
/******/        return getter;
/******/    };
/******/
/******/    // Object.prototype.hasOwnProperty.call
/******/    __webpack_require__.o = function(object,property) { return Object.prototype.hasOwnProperty.call(object,property); };
/******/
/******/    // __webpack_public_path__
/******/    __webpack_require__.p = "";
/******/
/******/
/******/    // Load entry module and return exports
/******/    return __webpack_require__(__webpack_require__.s = "./src/test.js");
/******/ })
/************************************************************************/
/******/ ({

/***/ "./src/test.js":
/*!*********************!*\
  !*** ./src/test.js ***!
  \*********************/
/*! exports provided: default */
/***/ (function(module,__webpack_exports__,__webpack_require__) {

"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__,\"default\",function() { return Person; });\nfunction _classCallCheck(instance,Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target,props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target,descriptor.key,descriptor); } }\n\nfunction _createClass(Constructor,protoProps,staticProps) { if (protoProps) _defineProperties(Constructor.prototype,protoProps); if (staticProps) _defineProperties(Constructor,staticProps); return Constructor; }\n\nvar Person = /*#__PURE__*/function () {\n  function Person() {\n    _classCallCheck(this,Person);\n\n    this.name = \"Jon Doe\";\n  }\n\n  _createClass(Person,[{\n    key: \"getName\",\n    value: function getName() {\n      return this.name;\n    }\n  }]);\n\n  return Person;\n}();\n\n\n\n//# sourceURL=webpack://testObj/./src/test.js?");

/***/ })

/******/ });
});

main.js

let person = new testObj.default;
console.log(person.getName());

输出

琼·多伊

现在,您可以看到我得到了相同的结果,但是这样做是

let person = new testObj.default;

这是我的第一个问题,我的babel / webpack配置有问题吗?

在控制台中看起来像这样

enter image description here

我很困惑,如果我尝试通过导入进行操作,我也会收到错误消息

index.html

<body>       
    <script src="./main.js" type="module"></script>
</body>

main.js

import Person from "../dist/test.js";

console.log(Person);

enter image description here

我还没有完全理解这些概念,但是让我更加困惑的是,例如,在Phaser 3中,我可以轻松地从 dist 文件夹导入一个类(通过npm),例如import phaser from 'phaser',它也是通过webpack生成的,并且效果很好。我的配置中缺少什么才能与导入的ES6配合使用?

我做了这个结论和困惑的最基本的例子。有人可以帮我吗?

谢谢。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)