I've been working through "A Journey to Angular Development" by Sukesh Marla and am having issues at a section where webpack-dev-server is introduced. At this point the textbook has yet to get into Angular dev, this is a prerequisite chapter focused on Webpack.
Previously in the chapter, a basic example project was created consisting of the following files:
//lib1.js
export function getLib1Message() {
return getMessage();
}
function getMessage() {
return "lib1";
}
//lib2.js
import {getLib1Message} from "./lib1.js";
export function getLib2Message() {
return getLib1Message() + " & " + getMessage();
}
function getMessage() {
return "lib2";
}
//test.js
import {getLib2Message} from "./lib2.js";
alert(getLib2Message());
<!-- index.html -->
<html>
<head>
<title>
JS Webpack Demo
</title>
<script src="./dist/main.js"></script>
</head>
</html>
The scripts are named as the comments describe them. These are the only files present in the folder/directory where I am running the webpack-dev-server command mentioned later. For this example, the author does not indicate any usage of a webpack config file.
After installing webpack-dev-server...
npm install webpack-dev-server -g
...the author instructs us to run the following command to launch the server:
webpack-dev-server --entry ./test.js --output-filename ./dist/main.js
The author then demonstrates that the server should be running on localhost:8080
However, when I open a web browser and attempt to access the server via this domain, I receive a white page with the text "Cannot GET /"
The following is output in the Command prompt window when I run the command:
C:\Users\juric\OneDrive\Documents\_AngularWorkspace\Chapter_6_Webpack\5_Using_devserver>webpack-dev-server --entry ./test.js --output-filename ./dist/main.js
<i> [webpack-dev-server] Project is running at:
<i> [webpack-dev-server] Loopback: http://localhost:8080/
<i> [webpack-dev-server] On Your Network (IPv4): http://[IP_ADDRESS_REMOVED_FOR_QUESTION]:8080/
<i> [webpack-dev-server] Content not from webpack is served from 'C:\Users\juric\OneDrive\Documents\_AngularWorkspace\Chapter_6_Webpack\5_Using_devserver\public' directory
asset ./dist/main.js 122 KiB [emitted] [minimized] (name: main) 1 related asset
orphan modules 31.9 KiB [orphan] 14 modules
runtime modules 27.2 KiB 12 modules
cacheable modules 177 KiB
modules by path ../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/node_modules/ 105 KiB
modules by path ../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/node_modules/...(truncated) 5.3 KiB 4 modules
modules by path ../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/node_modules/...(truncated) 81.3 KiB 4 modules
../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/node_modules/...(truncated) 4.16 KiB [built] [code generated]
../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/node_modules/...(truncated) 14.5 KiB [built] [code generated]
modules by path ../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/client/ 71.8 KiB
../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/client/index....(truncated) 42.4 KiB [built] [code generated]
../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/clien...(truncated) 1.15 KiB [built] [code generated]
../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/client/client...(truncated) 2.22 KiB [built] [code generated]
../../../../../AppData/Roaming/npm/node_modules/webpack-dev-server/client/module...(truncated) 26 KiB [built] [code generated]
./test.js + 2 modules 392 bytes [built] [code generated]
WARNING in configuration
The 'mode' option has not been set, webpack will fallback to 'production' for this value.
Set 'mode' option to 'development' or 'production' to enable defaults for each environment.
You can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/configuration/mode/
webpack 5.83.1 compiled with 1 warning in 1554 ms
When I pull open the web browser Console in Google Chrome, I do notice the following messages:
Failed to load resource: the server responded with a status of 404 (Not Found)
DevTools failed to load source map: Could not load content for chrome-extension://ehkepjiconegkhpodgoaeamnpckdbblp/content.js.map: System error: net::ERR_BLOCKED_BY_CLIENT
And when I pull open the web browser Console in Microsoft Edge, I see the following messages:
POST https://api-js.mixpanel.com/track/?verbose=1&ip=1&_=1684537407444 net::ERR_BLOCKED_BY_CLIENT
GET https://api-js.mixpanel.com/decide/?verbose=1&version=3&lib=web&token=7dad82d18ad96fda165e06987365580e&distinct_id=00034001CE2601AE&ip=1&_=1684537408134 net::ERR_BLOCKED_BY_CLIENT
POST https://api-js.mixpanel.com/engage/?verbose=1&ip=1&_=1684537408026 net::ERR_BLOCKED_BY_CLIENT
GET https://api-js.mixpanel.com/decide/?verbose=1&version=1&lib=web&token=7dad82d18ad96fda165e06987365580e&ip=1&_=1684537408033 net::ERR_BLOCKED_BY_CLIENT
GET https://api-js.mixpanel.com/decide/?verbose=1&version=3&lib=web&token=7dad82d18ad96fda165e06987365580e&distinct_id=00034001CE2601AE&ip=1&_=1684537408514 net::ERR_BLOCKED_BY_CLIENT
GET https://api-js.mixpanel.com/decide/?verbose=1&version=1&lib=web&token=7dad82d18ad96fda165e06987365580e&ip=1&_=1684537408387 net::ERR_BLOCKED_BY_CLIENT
According to the webpack-dev-server
documentation the default --static
path is public
so if you want to use a different folder you must indicate it in the static
flag, let's assume you want it to be the src
folder your command should look like this:
webpack-dev-server --entry ./test.js --output-filename ./dist/main.js --static ./src/
In your case it seems that you have the file index.html
in the root folder at the same level as test.js
so your command should look like this
webpack-dev-server --entry ./test.js --output-filename ./dist/main.js --static .
For more information, webpack-dev-server cli options