从本地网络访问Webpack Dev Server? (在移动设备上实现热重新加载)

时间:2016-06-02 21:54:45

标签: javascript reactjs webpack

我想从本地网络上的设备测试React网站。它适用于其他PC,但不适用于我的手机。

你们有什么想法会导致这种情况吗?这是我的配置文件的外观:

const webpack = require('webpack');
const path = require('path');

module.exports = {

    entry: {
        mainFeedPage: [
            'webpack/hot/only-dev-server',
            './src/mainFeedPage.js'
        ],
        venues: [
            'webpack/hot/only-dev-server',
            './src/venues.js'
        ],  
        artists: [
            'webpack/hot/only-dev-server',
            './src/artists.js'
        ]  
    },
    output: {
        path: path.resolve(__dirname, 'public'),
        filename: 'js/[name].js',
        publicPath: '/public/'
    },
    devServer: {
        inline:true,
        port: 4000,
        hot: true,
        colors: true,
        progress: true,
        host: '0.0.0.0'

    },
    module: {
        loaders: [
            {
                test: /\.jsx?$/,
                exclude: /node_modules/,
                loaders: [
                    'react-hot', 
                    'babel?presets[]=react,presets[]=es2015'
                ] 
            }
        ]
    },

    plugins: [
        new webpack.HotModuleReplacementPlugin(),
        new webpack.NoErrorsPlugin(),
        new webpack.optimize.CommonsChunkPlugin({

            // Export bundles for each entry and one for code they share
            name: "shared",
            filename: "js/shared.js",
            chunks: ["mainFeedPage", "venues"]
        })
    ],

    resolve: {
        modulesDirectories: ['node_modules', 'src', 'components', 'stores'],
        extensions: ['', '.js', '.scss'],
        root: [path.join(__dirname, './src')],
    }
};

更新尝试了这一点,但无法让它发挥作用:https://github.com/gaearon/react-hot-loader/issues/107#issuecomment-85712166

2 个答案:

答案 0 :(得分:0)

这不是一个直接修复,但我有一个基于Dan Abramov提供的React Transform样板的项目,它可以在移动Android设备上完美运行。 Haven未在iOS上测试过。它在原理上与React Hot Loader非常相似:https://github.com/gaearon/react-transform-boilerplate

它已被弃用,但在版本3发布之前,React Hot Loader也是如此。

不可否认,这个解决方案'可能就像用大锤击打钉子一样。希望有人可以提供更简单的东西,不需要交换一堆依赖关系和构建配置。

答案 1 :(得分:0)

Christian's example解决了我的问题。如果要使用捆绑包,则必须自定义webpack.config文件。这可以通过谷歌搜索解决,但我花了很多时间来了解Node和Express如何工作......