自己找到答案了。这是webpack
的语法,用于激活loader
的。
在webpack - loaders
下有一句话:
Loaders are activated by using loadername!
prefixes in require()
statements, or are automatically applied via regex from your webpack configuration
意思就是,可以通过loadername!
的方式调用loader
,也可以通过配置文件内的正则规则自动启用。
因此,对于问题中的两个例子,
require("any-template-language-loader!./xyz.atl");
表示使用any-template-language-loader
来加载./xyz.atl
这个文件。
vscode同理,
import 'vs/css!./actionbar';
表示使用vs/css
来加载./actionbar.css
这个文件。
而vs/css
这个loader
是在src/vs/css.build.js
这个文件中注册的:
// vscode - src/vs/css.build.js:360
define('vs/css', new CSSPlugin(cssLoader));
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…