Brunch 源映射:未在 Chrome devtools 中命中断点
Brunch source mapping: not hitting breakpoints in Chrome devtools
我正在使用内置于 B运行ch 中的默认源映射。我看到文件很好,但我无法在源映射文件中设置断点。通过 debugger;
使用 Javascript 访问调试器是可行的,这让我相信 B运行ch 方面有问题。
这是我的b运行ch-config.js:
module.exports = {
files: {
javascripts: {
joinTo: {
'js/vendor.js': /^(?!source\/)/,
'js/app.js': /^source\//
},
entryPoints: {
'source/scripts/app.jsx': 'js/app.js'
},
order: {
before: /^(?!source)/
}
},
stylesheets: {joinTo: 'css/core.css'},
},
paths: {
watched: ['source']
},
modules: {
autoRequire: {
'js/app.js': ['source/scripts/app']
}
},
plugins: {
babel: {presets: ['latest', 'react']},
assetsmanager: {
copyTo: {
'assets': ['source/resources/*']
}
},
static: {
processors: [
require('html-brunch-static')({
processors: [
require('pug-brunch-static')({
fileMatch: 'source/views/home.pug',
fileTransform: (filename) => {
filename = filename.replace(/\.pug$/, '.html');
filename = filename.replace('views/', '');
return filename;
}
})
]
})
]
}
},
server: {
run: true,
port: 9005
}
};
我尝试将配置的 sourceMaps
属性 设置为 'old'
和 'absoluteUrl'
以及 'inline'
(请参阅 Brunch config 文档)但是我仍然没有遇到断点。
我 运行 命令 brunch watch --server
我正在使用 Chrome。 Chrome Canary 中的行为相同。我在 Firefox 中打了断点,没问题。
有趣的是,源地图文件的定义似乎有一个 base 64 字符串,类似于:
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpb...
映射似乎有效,但为什么我不能在 Chrome devtools 中设置断点?
MVCE 可用。请遵循以下说明:
- 克隆此 example repository
npm install
brunch build
(确保使用 npm install brunch -g
全局安装)
- 在Chrome devtools中打开并设置断点
- 重新加载应用程序以尝试命中断点
有关更多信息,这是我的 package.json:
{
"version": "0.0.1",
"devDependencies": {
"assetsmanager-brunch": "^1.8.1",
"babel-brunch": "^6.1.1",
"babel-plugin-add-module-exports": "^0.2.1",
"babel-plugin-rewire": "^1.0.0-rc-5",
"babel-plugin-transform-es2015-modules-commonjs": "^6.10.3",
"babel-plugin-transform-object-rest-spread": "^6.8.0",
"babel-preset-react": "^6.3.13",
"babel-register": "^6.11.6",
"browser-sync-brunch": "^0.0.9",
"brunch": "^2.10.9",
"brunch-static": "^1.2.1",
"chai": "^3.5.0",
"es6-promise": "^3.2.1",
"eslint-plugin-react": "^5.1.1",
"expect": "^1.20.2",
"html-brunch-static": "^1.3.2",
"jquery": "~2.1.4",
"jquery-mousewheel": "^3.1.13",
"mocha": "^3.0.0",
"nib": "^1.1.0",
"nock": "^8.0.0",
"oboe": "~2.1.2",
"paper": "0.9.25",
"path": "^0.12.7",
"pug": "^2.0.0-beta10",
"pug-brunch-static": "^2.0.1",
"react": "^15.2.1",
"react-dom": "^15.2.1",
"react-redux": "^4.4.5",
"redux": "^3.5.2",
"redux-logger": "^2.6.1",
"redux-mock-store": "^1.1.2",
"redux-promise": "^0.5.3",
"redux-thunk": "^2.1.0",
"reselect": "^2.5.3",
"spectrum-colorpicker": "~1.8.0",
"stylus-brunch": "^2.10.0",
"uglify-js-brunch": "^2.10.0",
"unibabel": "~2.1.0",
"when": "~3.4.5"
},
"dependencies": {
"jwt-decode": "^2.1.0",
"lodash": "^4.17.4",
"postal": "^2.0.5",
"rc-tree": "^1.3.9"
},
"scripts": {
"test": "mocha --compilers js:babel-register"
}
}
Issue 创建于 b运行ch 的 Github.
更新
按照@JohannesFilter 对 .
的回答中指定的方式修复我的 b运行ch 配置来解决
这是有效但冲突的 Brunch 配置的副产品。请参阅@JohannesFilter 对此 的回答。
本质上,files.joinTo
和 files.entryPoints
似乎是互斥的,因为如果它们重叠,files.entryPoints
将覆盖 files.joinTo
的输出。解决方案是选择一个或另一个,或者确保它们不会与正在处理的文件重叠。例如,这两个都是工作配置:
entryPoints: {
'source/scripts/app.jsx': {
'js/vendor.js': /^(?!source\/)/,
'js/app.js': /^source\//
},
}
或
joinTo: {
'js/lib.js': /^(?!source\/)/
},
entryPoints: {
'source/scripts/app.jsx': {
'js/app.js': /^source\//
},
}
我正在使用内置于 B运行ch 中的默认源映射。我看到文件很好,但我无法在源映射文件中设置断点。通过 debugger;
使用 Javascript 访问调试器是可行的,这让我相信 B运行ch 方面有问题。
这是我的b运行ch-config.js:
module.exports = {
files: {
javascripts: {
joinTo: {
'js/vendor.js': /^(?!source\/)/,
'js/app.js': /^source\//
},
entryPoints: {
'source/scripts/app.jsx': 'js/app.js'
},
order: {
before: /^(?!source)/
}
},
stylesheets: {joinTo: 'css/core.css'},
},
paths: {
watched: ['source']
},
modules: {
autoRequire: {
'js/app.js': ['source/scripts/app']
}
},
plugins: {
babel: {presets: ['latest', 'react']},
assetsmanager: {
copyTo: {
'assets': ['source/resources/*']
}
},
static: {
processors: [
require('html-brunch-static')({
processors: [
require('pug-brunch-static')({
fileMatch: 'source/views/home.pug',
fileTransform: (filename) => {
filename = filename.replace(/\.pug$/, '.html');
filename = filename.replace('views/', '');
return filename;
}
})
]
})
]
}
},
server: {
run: true,
port: 9005
}
};
我尝试将配置的 sourceMaps
属性 设置为 'old'
和 'absoluteUrl'
以及 'inline'
(请参阅 Brunch config 文档)但是我仍然没有遇到断点。
我 运行 命令 brunch watch --server
我正在使用 Chrome。 Chrome Canary 中的行为相同。我在 Firefox 中打了断点,没问题。
有趣的是,源地图文件的定义似乎有一个 base 64 字符串,类似于:
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpb...
映射似乎有效,但为什么我不能在 Chrome devtools 中设置断点?
MVCE 可用。请遵循以下说明:
- 克隆此 example repository
npm install
brunch build
(确保使用npm install brunch -g
全局安装)- 在Chrome devtools中打开并设置断点
- 重新加载应用程序以尝试命中断点
有关更多信息,这是我的 package.json:
{
"version": "0.0.1",
"devDependencies": {
"assetsmanager-brunch": "^1.8.1",
"babel-brunch": "^6.1.1",
"babel-plugin-add-module-exports": "^0.2.1",
"babel-plugin-rewire": "^1.0.0-rc-5",
"babel-plugin-transform-es2015-modules-commonjs": "^6.10.3",
"babel-plugin-transform-object-rest-spread": "^6.8.0",
"babel-preset-react": "^6.3.13",
"babel-register": "^6.11.6",
"browser-sync-brunch": "^0.0.9",
"brunch": "^2.10.9",
"brunch-static": "^1.2.1",
"chai": "^3.5.0",
"es6-promise": "^3.2.1",
"eslint-plugin-react": "^5.1.1",
"expect": "^1.20.2",
"html-brunch-static": "^1.3.2",
"jquery": "~2.1.4",
"jquery-mousewheel": "^3.1.13",
"mocha": "^3.0.0",
"nib": "^1.1.0",
"nock": "^8.0.0",
"oboe": "~2.1.2",
"paper": "0.9.25",
"path": "^0.12.7",
"pug": "^2.0.0-beta10",
"pug-brunch-static": "^2.0.1",
"react": "^15.2.1",
"react-dom": "^15.2.1",
"react-redux": "^4.4.5",
"redux": "^3.5.2",
"redux-logger": "^2.6.1",
"redux-mock-store": "^1.1.2",
"redux-promise": "^0.5.3",
"redux-thunk": "^2.1.0",
"reselect": "^2.5.3",
"spectrum-colorpicker": "~1.8.0",
"stylus-brunch": "^2.10.0",
"uglify-js-brunch": "^2.10.0",
"unibabel": "~2.1.0",
"when": "~3.4.5"
},
"dependencies": {
"jwt-decode": "^2.1.0",
"lodash": "^4.17.4",
"postal": "^2.0.5",
"rc-tree": "^1.3.9"
},
"scripts": {
"test": "mocha --compilers js:babel-register"
}
}
Issue 创建于 b运行ch 的 Github.
更新
按照@JohannesFilter 对
这是有效但冲突的 Brunch 配置的副产品。请参阅@JohannesFilter 对此
本质上,files.joinTo
和 files.entryPoints
似乎是互斥的,因为如果它们重叠,files.entryPoints
将覆盖 files.joinTo
的输出。解决方案是选择一个或另一个,或者确保它们不会与正在处理的文件重叠。例如,这两个都是工作配置:
entryPoints: {
'source/scripts/app.jsx': {
'js/vendor.js': /^(?!source\/)/,
'js/app.js': /^source\//
},
}
或
joinTo: {
'js/lib.js': /^(?!source\/)/
},
entryPoints: {
'source/scripts/app.jsx': {
'js/app.js': /^source\//
},
}