webpack-dev-server不会监视我的文件更改

时间:2015-04-18 20:56:21

标签: npm webpack webpack-dev-server

当我在webpack-dev-server运行时更改文件时,捆绑包的文件不会更新。 这是我的webpack.config.js和package.json文件,你可以从我的npm脚本中看到,我已经解决了在同一个命令中运行webpack watchwebpack-dev-server的问题({{1} }):

webpack.config.js:

npm run watch &  webpack-dev-server --content-base ./ --port 9966

的package.json:

'use strict';

var ReactStylePlugin = require('react-style-webpack-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');

var webpack = require('webpack');

module.exports = {
    devtool: 'sourcemap',
  entry: ['./js/main.js'],
  output: {
    filename: 'bundle.js',
    path: __dirname + '/assets',
    publicPath: __dirname + '/'
  },
  module: {
    loaders: [
      {
        test: /\.js$/,
        loaders: [
          ReactStylePlugin.loader(),
          'jsx-loader?harmony'
        ]
      },
      {
        test: /\.css$/,
        loader: ExtractTextPlugin.extract('css-loader')
      }
    ]
  },
  plugins: [
    new ReactStylePlugin('bundle.css'),
    new webpack.DefinePlugin({
      'process.env': {
        // To enable production mode:
        //NODE_ENV: JSON.stringify('production')
      }
    })
  ]
}

我的目录结构是:

{
  "name": "reactTest",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "watch": "webpack --watch",
    "build": "webpack",
    "web": "npm run watch &  webpack-dev-server --content-base ./ --port 9966"
  },
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "css-loader": "^0.10.1",
    "extract-text-webpack-plugin": "^0.3.8",
    "jsx-loader": "^0.13.1",
    "react-style-webpack-plugin": "^0.4.0",
    "style-loader": "^0.10.2",
    "url-loader": "^0.5.5",
    "webpack": "^1.8.5",
    "webpack-dev-server": "^1.8.0"
  },
  "dependencies": {
    "react": "^0.13.1",
    "react-style": "^0.5.3"
  }
}

assets bundle.css bundle.css.map bundle.js bundle.js.map js AppActions.js Profile.css.js ProfileList.js main.js AppConstants.js AppStore.js Profile.js ResultPage.js package.json index.html node_modules webpack.config.js 目录中的每个文件都是由webpack生成的

5 个答案:

答案 0 :(得分:37)

你需要使用--hot标志运行webpack-dev-server:

webpack-dev-server --content-base ./ --port 9966 --hot

然后您可以访问热门版本localhost:9966 / webpack-dev-server /

您也不需要观看。

更新

您的webpack配置中的此条目必须更改:

entry: ['./js/main.js'], - > entry: ['webpack/hot/dev-server' , './js/main.js']

更改您的publicPath条目:

publicPath: '/assets/'

答案 1 :(得分:37)

为了让webpack观察我的文件更改(Ubuntu 14.04),我不得不增加观察者的数量(之前我增加了数量,但它仍然太低):

echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p

官方文档中的来源:https://webpack.github.io/docs/troubleshooting.html#not-enough-watchers

我首先怀疑原因是fsevents在Ubuntu上不起作用,但显然事实并非如此。

此外,因为现在观看和重新编译工作,但自动浏览器刷新部分不起作用,我将--inline参数添加到@deowk的答案,它启用“内联模式”: webpack-dev-server --content-base ./ --port 9966 --hot --inline

来自官方文档的引用:“使用热线模块替换与webpack-dev-server的最简单方法是使用内联模式。” 资料来源:https://webpack.github.io/docs/webpack-dev-server.html#hot-module-replacement

答案 2 :(得分:12)

@funkybunky确定了正确的问题,但(恕我直言)以错误的方式修复了它。至少在我的情况下,webpack试图观察它使用的每个文件,包括从List<string>中提取的数千个依赖文件的深层链。我将此添加到我的配置per the docs

ViewModel

当然,你可以合法地拥有数千个可能需要观看的文件,在这种情况下继续提高限制,但你最好忽略那些不太可能改变的供应商库。

答案 3 :(得分:3)

我会把它放在这里以防万一它可以帮助任何人。我的问题是一样的,但是由于目录名称和webpack别名声明的大写不一致而导致。

我有一个WebGL目录,我在别名中引用了webgl,不幸的是这适用于构建,但不适用于代码监视。

答案 4 :(得分:0)

在我的情况下,错误是由目录名中的空白空间引起的,通过更改&#34;存储库名称&#34;通过&#34; RepositoryName&#34;,一切正常!