This repository was archived by the owner on Apr 14, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathhmr_example.js
More file actions
35 lines (33 loc) · 1.27 KB
/
hmr_example.js
File metadata and controls
35 lines (33 loc) · 1.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
document.write("Open the javascript console!");
var context = require.context("./filesToLoad", false, /\.js$/);
var modules = {};
context.keys().forEach(function (key) {
var module = context(key);
modules[key] = module;
customReloadLogic(key, module, false);
})
if (module.hot) {
module.hot.accept(context.id, function () {
//You can't use context here. You _need_ to call require.context again to
//get the new version. Otherwise you might get errors about using disposed
//modules
var reloadedContext = require.context("./filesToLoad", false, /\.js$/);
//To find out what module was changed you just compare the result of the
//require call with the version stored in the modules hash using strict
//equality. Equal means it is unchanged.
var changedModules = reloadedContext.keys()
.map(function (key) {
return [key, reloadedContext(key)];
})
.filter(function (reloadedModule) {
return modules[reloadedModule[0]] !== reloadedModule[1];
});
changedModules.forEach(function (module) {
modules[module[0]] = module[1];
customReloadLogic(module[0], module[1], true);
});
});
}
function customReloadLogic(name, module, isReload) {
console.log("module " + name + (isReload ? " re" : " ") + "loaded");
}