微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在 TypeScript 中动态导入 SCSS

如何解决在 TypeScript 中动态导入 SCSS

我使用 Create React App (CRA) 设置了一个新项目,然后添加node-sass 以便能够导入 SCSS 文件

示例:

import "./App.scss";

虽然这工作正常,但我无法使用 import() 异步加载样式。我在纯 JavaScript 项目中使用了这种技术,但是自从将它转换为 TypeScript 后,我​​得到以下编译器错误

找不到模块“./fallback.scss”或其对应的类型声明。 TS2307

这是产生问题的代码的 MVE:

async function loadFallbackStyles(): Promise<void> {
    if (window.navigator.userAgent.includes("Trident/")) {
        await import("./fallback.scss");
    }
}

我已经尝试将 declare module "*.scss" 添加到我的类型声明中,但无济于事。

解决方法

在正确的声明文件中使用 declare module "*.scss" 会起作用。我已经把它放在 global.d.ts 中,错误消失了。

我仍然想知道为什么静态导入开箱即用,所以请随时发布更深入的答案!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。