7

我正在尝试使用 webpack 构建一个 umd 库;无论我做什么都会收到警告:

D:/Code/Node/sample.io/source/index.ts 3:24 中的警告 关键依赖项:require 函数的使用方式不能静态提取依赖项

当我尝试require('./index.js')生成的 index.js 时,我得到:

错误:找不到模块“。”

为了完整起见,这里是我的所有文件:

webpack.config.js:

module.exports = {
  entry: {
    index: __dirname + '/index'
  },
  output: {
    filename: 'index.js',
    library: 'mylib',
    libraryTarget: 'umd',
    umdNamedDefine: true
  },
  resolve: {
    root: __dirname,
    extensions: ['', '.ts', '.js'],
  },
  module: {
    loaders: [
      { test: /\.ts$/, loaders: ['awesome-typescript-loader'] }
    ]    
  }
}

tsconfig.json:

{
  "compilerOptions": {
    "target": "es5",
    "module": "umd"
  },
  "exclude": [
    "node_modules"
  ]
}

包.json:

{
  "name": "foo",
  "version": "0.1.0",
  "devDependencies": {
    "awesome-typescript-loader": "^2.0.2",
    "typescript": "^2.0.0",
    "webpack": "^2.1.0-beta.17"
  }
}

索引.ts:

export function MyFunc(params) {
  console.log("hello world");
}
  • node -v= v6.3.0
  • npm -v= 3.7.5

奇怪的是,我的一个朋友说这对他们来说没有错误。虽然他在node 4.2.6。如果我将模块更改为 commonjs,它可以正常工作而不会出现警告或错误。

4

2 回答 2

22

我认为您需要"module": "commonjs"在 tsconfig 中,因此 typescript 编译将发出 webpack 可以理解的模块,您仍然会从 webpack 获得 umd 输出

希望这可以帮助

于 2016-07-15T12:07:20.253 回答
4

如果您无法将modulefrom更改umdcommonjs因为您只是在使用它,并且您无权访问源代码,则可以将umd-compat-loader其用作解决方法。将以下内容添加rule到您的webpack.config.js:

module: {
    rules: [
        // other rules come here.
        {
            test: /node_modules[\\|/](name-of-the-umd-package)/,
            use: { loader: 'umd-compat-loader' }
        }
    ]
},

我在这个线程中添加了更多细节。

于 2018-02-16T09:44:03.400 回答