2016-05-17 170 views
1

在開發中的某個地方,這個錯誤開始顯示,我無法確定它來自哪裏。錯誤是爲了我的知識'廣泛'。我正在使用webpack和gulp。如果任何人都能指引我走向正確的方向。找不到模塊捆綁

我可以發佈更多的代碼,但你需要告訴我什麼文件。該應用程序工作,因爲它應該,REST,頁面加載等。只有CSS不顯示。

Starting gatling-rsync-deamon... 

Starting containers... 
Starting vagrant_redis_1 
Starting vagrant_mongo_1 
Starting vagrant_app_1 
Connection to 127.0.0.1 closed. 

launching stream... 
[14:39:00] Requiring external module babel-register 
[14:39:14] Using gulpfile /var/www/app/gulpfile.babel.js 
[14:39:14] Starting 'set-dev-env'... 
NODE_ENV will be set to development... 
[14:39:14] Finished 'set-dev-env' after 310 μs 
[14:39:14] Starting 'backend-watch'... 
[14:39:14] Backend warming up... 
[14:39:14] Starting 'frontend-watch'... 
[14:39:15] Finished 'frontend-watch' after 694 ms 
[14:39:15] Starting 'server'... 
[14:39:15] Finished 'server' after 1.55 ms 
Webpack-dev-server listening at localhost:9090. 

module.js:340 
    throw err; 
     ^
Error: Cannot find module '/var/www/app/build/bundle' 
    at Function.Module._resolveFilename (module.js:338:15) 
    at Function.Module._load (module.js:280:25) 
    at Function.Module.runMain (module.js:497:10) 
    at startup (node.js:119:16) 
    at node.js:945:3 
[14:39:20] Finished 'backend-watch' after 5.25 s 
[14:39:20] Starting 'dev'... 
[14:39:20] Finished 'dev' after 3.46 μs 
Hash: 5e15e9e5b2fd1c868120 
Version: webpack 1.13.0 

gulpfile.babel.js

import webpack from 'webpack'; 
import WebpackDevServer from 'webpack-dev-server'; 
import gulp from 'gulp'; 
import gutil from 'gulp-util'; 
import nodemon from 'nodemon'; 
import path from 'path'; 
import jsdoc from 'gulp-jsdoc3'; 
import WebpackDevMiddleware from 'webpack-dev-middleware'; 
import webpackHotMiddleware from 'webpack-hot-middleware'; 
// import backendConfig from './config/webpack.backend.config.js'; 
// import frontendConfig from './config/webpack.frontend.config.js'; 

import configs from './config/webpack.config'; 
import jsdocConfig from './config/jsdoc.config'; 

const [frontendConfig, backendConfig] = configs; 


const FRONTEND_PORT = 8085; 
const BACKEND_PORT = 9090; 

function onBuild(err, stats) { 
    if (err) { 
    throw new Error(err); 
    } 
    console.log(stats.toString()); 
} 

// Default: list all tasks. 
gulp.task('default',() => { 
    console.log('Available commands: dev, build'); 
}); 

// Start frontend 
gulp.task('frontend', (done) => { 
    webpack(frontendConfig).run((err, stats) => { 
    onBuild(err, stats); 
    done(); 
    }); 
}); 

// Start frontend watch 
gulp.task('frontend-watch',() => { 
    const webpackDevserver = new WebpackDevServer(webpack(frontendConfig), { 
    publicPath: frontendConfig.output.publicPath, 
    stats: { colors: true }, 
    historyApiFallback: true, 
    proxy: { 
     '*': `http://localhost:${BACKEND_PORT}` 
    } 
    }); 
    webpackDevserver.listen(BACKEND_PORT, 'localhost', (err, result) => { 
    if (err) { 
     console.log(err); 
    } 
    else { 
     console.log(`Webpack-dev-server listening at localhost:${BACKEND_PORT}.`); 
    } 
    }); 
}); 

// Start backend 
gulp.task('backend', (done) => { 
    webpack(backendConfig).run((err, stats) => { 
    onBuild(err, stats); 
    done(); 
    }); 
}); 

// Start backend watch 
gulp.task('backend-watch', (done) => { 
    gutil.log('Backend warming up...'); 
    let firedDone = false; 

    webpack(backendConfig).watch(100, (err, stats) => { 
    if (!firedDone) { done(); firedDone = true; } 
    onBuild(err, stats); 
    nodemon.restart(); 
    }); 
}); 

// 
// gulp.task('run', ['set-dev-env', 'backend-watch'],() => { 
// nodemon({ 
//  execMap: { 
//  js: 'node' 
//  }, 
//  script: path.join(__dirname, 'build/backend'), 
//  ignore: ['*'], 
//  watch: ['foo/'], 
//  ext: 'noop' 
// }).on('restart',() => { 
//  console.log('Patched!'); 
// }); 
// }); 

// Set NODE_ENV to development 
gulp.task('set-dev-env',() => { 
    console.log('NODE_ENV will be set to development...'); 
    process.env.NODE_ENV = 'development'; 
}); 

// Set NODE_ENV to production 
gulp.task('set-prod-env',() => { 
    console.log('NODE_ENV will be set to production...'); 
    process.env.NODE_ENV = 'production'; 
}); 

// Start server 
gulp.task('server',() => { 
    nodemon({ 
    execMap: { 
     js: 'node' 
    }, 
    script: path.join(__dirname, 'build/bundle'), 
    ignore: ['*'], 
    watch: ['foo/'], 
    ext: 'noop' 
    }).on('restart',() => { 
    console.log('Server restarted!'); 
    }); 
}); 

// Generate docs 
gulp.task('docs', (cb) => { 
    // gulp.src(['README.md', './client/**/*.js', './server/**/*.js'], { read: false }) 
    //  .pipe(jsdoc(jsdocConfig, cb)); 
}); 

// Build project 
gulp.task('build', ['set-prod-env', 'build-js']); 

// Build backend & frontend 
gulp.task('build-js', ['backend', 'frontend']); 

// Watch backend & frontend 
gulp.task('watch', ['backend-watch', 'frontend-watch']); 

// Start development session 
gulp.task('dev', ['set-dev-env', 'backend-watch', 'frontend-watch', 'server']); 

webpack.config

import webpack from 'webpack'; 
import path from 'path'; 
import fs from 'fs'; 
import HtmlWebpackPlugin from 'html-webpack-plugin'; 
const embedFileSize = 50000; 

const nodeModules = {}; 
fs.readdirSync('node_modules') 
    .filter(module => { 
    return ['.bin'].indexOf(module) === -1; 
    }) 
    .forEach(mod => { 
    nodeModules[mod] = 'commonjs ' + mod; 
    }); 

const frontendConfig = { 
    entry: [ 
    'webpack-hot-middleware/client', 
    path.join(__dirname, '../client/index.js') 
    ], 

    output: { 
    filename: 'bundle.js', 
    path: path.join(__dirname, 'build', 'public') 
    }, 

    devtool: 'sourcemap', 

    plugins: [ 
    new HtmlWebpackPlugin({ 
     template: './client/public/index.html', 
     inject: 'body', 
     filename: 'index.html' 
    }), 
    new webpack.ProvidePlugin({ 
     'Promise': 'es6-promise', 
     'fetch': 'imports?this=>global!exports?global.fetch!whatwg-fetch' 
    }), 
    new webpack.optimize.OccurenceOrderPlugin(), 
    new webpack.HotModuleReplacementPlugin(), 
    new webpack.NoErrorsPlugin(), 
    new webpack.DefinePlugin({ 
     'process.env.NODE_ENV': JSON.stringify('development'), 
     '__DEV__': JSON.stringify(process.env.NODE_ENV) 
    }) 
    ], 

    module: { 
    preloaders: [ 
     { test: /\.js$/, loader: 'eslint'} 
    ], 
    loaders: [ 
     { 
     test: /\.js?$/, 
     exclude: /node_modules/, 
     loader: 'babel-loader' 
     }, 
     { 
     test: /\.json?$/, 
     loader: 'json' 
     }, 
     { 
     test: /\.css$/, 
     loader: 'style-loader!css-loader?modules&&importLoaders=1&localIdentName=[name]---[local]---[hash:base64:5]!postcss-loader' 
     }, 
     { 
     test: /\.less$/, 
     loader: "style!css!less" 
     }, 
     { test: /\.svg/, 
     loader: 'url?limit=' + embedFileSize + '&mimetype=image/svg+xml' 
     }, 
     { test: /\.png$/, 
     loader: 'url?limit=' + embedFileSize + '&mimetype=image/png' 
     }, 
     { test: /\.jpg/, 
     loader: 'url?limit=' + embedFileSize + '&mimetype=image/jpeg' 
     }, 
     { test: /\.gif/, 
     loader: 'url?limit=' + embedFileSize + '&mimetype=image/gif' 
     }, 
     { 
     test: /\.(otf|eot|ttf|woff|woff2)(\?v=[0-9]\.[0-9]\.[0-9])?$/, 
     loader: 'url?limit=' + embedFileSize 
     } 
    ] 
    }, 
    resolve: { 
    extensions: ['', '.js', '.jsx', '.json', '.css'] 
    }, 
}; 

const serverConfig = { 
    entry: './server/server.js', 
    output: { 
    path: path.join(__dirname, '../build'), 
    filename: 'bundle.js' 
    }, 

    devtool: 'sourcemap', 

    target: 'node', 
    // do not include polyfills or mocks for node stuff 
    node: { 
    console: false, 
    global: false, 
    process: false, 
    Buffer: false, 
    __filename: false, 
    __dirname: false 
    }, 
    externals: nodeModules, 

    plugins: [ 
    // enable source-map-support by installing at the head of every chunk 
    new webpack.BannerPlugin('require("source-map-support").install();', 
     {raw: true, entryOnly: false}) 
    ], 

    module: { 
    loaders: [ 
     { 
     // transpile all .js files using babel 
     test: /\.js$/, 
     exclude: /node_modules/, 
     loader: 'babel' 
     } 
    ] 
    } 
}; 

export default [frontendConfig, serverConfig]; 
+0

請出示gulpfile.js和gulpfile.babel.js代碼 –

+0

@KrzysztofSztompka感謝您抽出寶貴的興趣。更新。 – 70656e6973

+0

請同時顯示./config/webpack.config –

回答

0

我的回答對現在的基礎上粘貼的代碼。當我獲得更多信息時,我會編輯這個答案。

林不知道如果我能爲你找到遠程正確的解決方案。但是你的問題可能是公共路徑被添加到webpack和WebpackDevServer。 WebpackDevServer沒有看到捆綁在bundle.js中的js代碼

+0

無法記得改變2個文件中的某個東西,很奇怪。我再次更新。 – 70656e6973

0

將目標更改爲「web」而不是節點。您應該編譯最有可能的web類型的環境,而不是像環境那樣的node.js。

target: 'web', 
+0

錯誤:無法在webpackMissingModule中找到模塊「fs」。 – 70656e6973

+0

現在做節點:{fs:'empty'}, –

+0

已經做到了。 fs.readdirSync('node_modules') ^ TypeError:Object# has no method'readdirSync' – 70656e6973