[英]TypeScript + Babel + Jest not using moduleNameMapper for less files
我将我的笑话配置设置为 map any.less 和.css 导入到identity-obj-proxy
模块,基本上在现有的每个文档引用/教程中都有规定。
module.exports = {
// ...
moduleNameMapper: {
'\\.(css|less)$': 'identity-obj-proxy',
},
};
但是,我发现当a.less文件包含一些无效css的forms(例如单行注释,调用mixins等)时,导入的object是空的。 这使我发现映射甚至没有被触发,并且一些其他机制(我还没有弄清楚,因为我没有设置这个项目)一直在从样式表生成 class 名称,而不是简单地使用代理。
import styles from './my-style-sheet.less'; // styles = {}
import * as styles from './my-style-sheet.less'); // styles = { default: {} }
import styles from './not-a-real-file.less'); // styles = {}
const styles = require('./my-style-sheet.less'); // styles = {}
对我来说真正奇怪的是,当我在调试并评估表达式require('./my-style-sheet.less')
时,它确实导入了代理模块。 事实上,我可以要求任何以.less
结尾的东西,它会导入代理,不管文件是否存在——这是我所期望的。
moduleNameMapper
中的其他模式正常工作,例如一些路径别名。
module.exports = {
// ...
moduleNameMapper: {
'^common': '<rootDir>/src/components/common',
},
};
我不知道发生了什么,也不知道如何调试它。
事实证明这是我们的babel.config.js
的问题。 我们正在添加babel-plugin-css-modules-transform
插件,它显然取代了moduleNameMapper
条目。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.