質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.59%

[Webpack] buildでエラーにならないのですが、Chromeコンソールを開くとエラーが表示される

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,111

sabx

score 168

 聞きたいこと

webpackでビルドした後に、webpack-dev-serverを起動すると、Chromeコンソールにエラーが下のように表示されます。

  • エラー
Uncaught ReferenceError: require is not defined
    at Object.events (external "events":1)
    at __webpack_require__ (bootstrap:19)
    at Object../node_modules/depd/lib/compat/index.js (index.js:14)
    at __webpack_require__ (bootstrap:19)
    at Object../node_modules/depd/index.js (index.js:11)
    at __webpack_require__ (bootstrap:19)
    at Object../node_modules/body-parser/index.js (index.js:14)
    at __webpack_require__ (bootstrap:19)
    at Object../node_modules/express/lib/express.js (express.js:15)
    at __webpack_require__ (bootstrap:19)

実装したファイルは下の通りです。

  • package.json
{
  "name": "test",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "build": "webpack",
    "dev": "webpack-dev-server --open"
  },
  "author": "",
  "license": "MIT",
  "devDependencies": {
    "babel-core": "^6.26.3",
    "babel-loader": "^7.0.4",
    "babel-preset-env": "^1.7.0",
    "express": "^4.16.3",
    "webpack": "^4.20.2",
    "webpack-cli": "^3.1.1",
    "webpack-dev-server": "^3.1.10"
  }
}
  • webpack.config.json
const path = require('path');

module.exports = {
  context: __dirname + '/src',
  mode: 'development',
  entry: {
    js: './src/js/main.js',
  },
  output: {
    path: path.join(__dirname, 'public/js'),
    filename: 'bundle.js'
  },
  module: {
    loaders: [{
      test: /\.js$/,
      loader: 'babel-loader',
      exclude: /node_modules/,
      query: { presets: ['es2015', 'stage-0'] }
    }]
  }
}
  • main.js
import express from 'express'
const app = express()

app.get('/', (req, res) => res.send('Hello World!'))

app.listen(3000, () => console.log('Example app listening on port 3000!'))
  • index.html
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>Super Mario</title>
  </head>
  <body>
    <script src="./js/bundle.js"></script>
  </body>
</html>

また、ディレクトリ構成は以下の通りです。

project/
 ├ node_module/
 ├ public/
    ├ js/
    │ └ bundle.js
    └ index.html
 ├ src/
 │ └ js/
 │   └ main.js
 ├ package-lock.json
 └ package.json

すいませんが、情報が不足していましたらコメントお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

expressはNode.js用のフレームワークで、ブラウザ内では動きません

ブラウザ内で使うJavaScriptに、expressを使う必要性はありません(サーバサイドはwebpack-dev-serverが引き受けてくれます)。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.59%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る