14

我已经安装了 proxyquire 并且我的 ajax.test.tsx 文件包含以下代码,只有 2 行

import * as proxyquire from 'proxyquire';
proxyquire.noCallThru();

我的 webpack 代码如下

module.exports = {
   entry: {
       "book.service": './src/book.service.ts',
       "ajax.test": './src/ajax.test.tsx'
   },
   output: {
       filename: "[name].js",
       path: __dirname + "/dist"
   },
   devtool: "source-map",
   watch: true,
   resolve: {
       extensions: [".tsx", ".tsx", ".js", ".json", ".ts", '.d.ts']
   },
   module: {
       rules: [
           { test: /\.tsx?$/, loader: "awesome-typescript-loader" },
           { enforce: "pre", test: /\.js$/, loader: "source-map-loader" }
       ]
   },
   externals: {
       'react/lib/ExecutionEnvironment': true,
       'react/addons': true,
       'react/lib/ReactContext': 'window'
   }
};

我已经安装了 proxyquire 和 @types/proxyquire。当我运行 webpack 命令时,它会抛出以下错误

 WARNING in ./~/proxyquire/lib/proxyquire.js
 require.extensions is not supported by webpack. Use a loader instead.
 @ ./~/proxyquire/index.js 3:17-44
 @ ./src/ajax.test.tsx

 ERROR in ./~/proxyquire/lib/proxyquire.js
 Module not found: Error: Can't resolve 'module' in '***\node_modules\pr
 oxyquire\lib'
4

3 回答 3

3

proxyquire 与 webpack 不兼容 - https://github.com/thlorenz/proxyquire/issues/62

问题

Proxyquire 使用 webpack 不支持的 require.extensions。

备择方案

于 2017-05-04T11:16:11.343 回答
1

Proxyquire 是为“node.js 模块系统”构建的,而不是 webpack 的。你必须使用与“前端”兼容的东西——inject-loader 或 webpack-rewire。

如果您不尊重 *-loaders 的简单性 - 您可以尝试rewiremock。它具有类似 proxyquire 的语法,并且可以在 node.js 和 webpack 环境中工作。

于 2017-10-22T23:37:56.803 回答
0

在您的 webpack.config.js 中更改以下行:

{ test: /\.tsx?$/, loader: "awesome-typescript-loader" }

至:

{ test: /\.tsx?$/, loader: "awesome-typescript-loader", exclude: /node_modules/ }

那应该可以解决您的问题。

于 2017-04-26T17:08:56.373 回答