如何在不捆绑的情况下在 Webpack-React 应用程序中加载外部配置文件?
How to load an external config file in a Webpack-React application without bundling it?
我有一个使用 React 编写并与 Webpack 捆绑在一起的 Web 应用程序。该应用程序有一个 JSON 配置文件,我想在运行时包含它而不是与 webpack 捆绑在一起。
在我的应用程序入口点,我使用 json-loader 导入内容,但这样做会强制将文件嵌入到应用程序中,一旦配置文件被嵌入,我就无法更新它捆绑。
如何配置我的 webpack.config.js 文件以排除我的 config.json 文件,但仍然允许我将它导入我的应用程序?它不是一个模块,所以我不知道它是否可以包含在我的 webpack.config.js
的 externals
部分中
我尝试使用 require.ensure,但我现在看到的只是 config.json 的内容捆绑到一个 1.1.bundle.js 文件中,更改配置文件没有任何作用。
app.js
let config;
require.ensure(['./config.json'], require => {
config = require('./config.json');
});
如果您的配置不是那么机密,您可以在 index.html
<script>
var initialState = {
config: {
idleTime: 120,
fetchStatusInterval: 8,
dataPath: 'somepath.json',
},
};
window.__INITIAL_STATE__ = initialState;
</script>
<script src="static/bundle.js"></script>
并且在你的 React 应用程序中
使用
获取您的配置
const applicationInitialState = window.__INITIAL_STATE__;
const config = applicationInitialState.config;
我最终使用它的修改版本从外部加载我的脚本。我的应用程序不需要立即进行配置,因此异步方面在这里没有任何区别。
我将其放在 <head>
应用程序入口页面的顶部,并带有一个位于同一位置的配置文件。
<head>
... other scripts
<script>
var config= window.config|| {};
$.getJSON('config.json', function(response) {
config= response;
});
</script>
</head>
<body>
<div id='root'/>
<script src='dist/app.bundle.js'></script>
</body>
我有一个使用 React 编写并与 Webpack 捆绑在一起的 Web 应用程序。该应用程序有一个 JSON 配置文件,我想在运行时包含它而不是与 webpack 捆绑在一起。
在我的应用程序入口点,我使用 json-loader 导入内容,但这样做会强制将文件嵌入到应用程序中,一旦配置文件被嵌入,我就无法更新它捆绑。
如何配置我的 webpack.config.js 文件以排除我的 config.json 文件,但仍然允许我将它导入我的应用程序?它不是一个模块,所以我不知道它是否可以包含在我的 webpack.config.js
的externals
部分中
我尝试使用 require.ensure,但我现在看到的只是 config.json 的内容捆绑到一个 1.1.bundle.js 文件中,更改配置文件没有任何作用。
app.js
let config;
require.ensure(['./config.json'], require => {
config = require('./config.json');
});
如果您的配置不是那么机密,您可以在 index.html
<script>
var initialState = {
config: {
idleTime: 120,
fetchStatusInterval: 8,
dataPath: 'somepath.json',
},
};
window.__INITIAL_STATE__ = initialState;
</script>
<script src="static/bundle.js"></script>
并且在你的 React 应用程序中 使用
获取您的配置const applicationInitialState = window.__INITIAL_STATE__;
const config = applicationInitialState.config;
我最终使用它的修改版本从外部加载我的脚本。我的应用程序不需要立即进行配置,因此异步方面在这里没有任何区别。
我将其放在 <head>
应用程序入口页面的顶部,并带有一个位于同一位置的配置文件。
<head>
... other scripts
<script>
var config= window.config|| {};
$.getJSON('config.json', function(response) {
config= response;
});
</script>
</head>
<body>
<div id='root'/>
<script src='dist/app.bundle.js'></script>
</body>