jspm / jQuery / TypeScript - 模块“jquery”没有默认导出

Posted

技术标签:

【中文标题】jspm / jQuery / TypeScript - 模块“jquery”没有默认导出【英文标题】:jspm / jQuery / TypeScript - module "jquery" has no default export 【发布时间】:2016-05-15 10:04:51 【问题描述】:

我正在尝试使用 TypeScript 和 jspm & system.js 引导 Web 应用程序以进行模块加载。我不会走得很远。安装jspm后,使用它安装jQuery:

jspm install jquery

基础知识:

<script src="jspm_packages/system.js"></script>
<script src="config.js"></script>
<script>
        System.import('main');
</script>

main.ts:

import $ from "jquery";

export class Application  
    constructor() 
        console.log($);
    

TypeScript 无法编译,因为“模块 'jquery' 没有默认导出。

生成的 config.js 有正确的映射:"jquery": "npm:jquery@2.2.0"

【问题讨论】:

你试过import * as $ from "jquery";吗? 谢谢你的作品!如果您将其作为答案提交,我可以接受。 这对我有用! 【参考方案1】:

当模块没有默认导出时,可以将完整的模块作为对象导入:import * as $ from "jquery";

或导入命名导出: import ajax, css from "jquery";

【讨论】:

命名导出不起作用。模块 jquery 没有导出的成员“css”。 别忘了运行:npm install jquery。 如果导出的模块是 CommonJS /AMD/UMD 格式(单个导出成员),TypeScript 文档指出您应该使用 import $ = require("jquery"); typescriptlang.org/docs/handbook/… 这两种方法都有优势吗?【参考方案2】:

如果您使用的是visual studio,请更新 typescript 插件。

要获取Visual Studio 2017的最新版本,go there

【讨论】:

以上是关于jspm / jQuery / TypeScript - 模块“jquery”没有默认导出的主要内容,如果未能解决你的问题,请参考以下文章

在我的 JSPM 包上使用 JSPM 404 进行 Karma/Jasmine 单元测试

jspm

在 VueJS + JSPM 中呈现为注释的组件

Karma + JSPM + Typescript - 未找到“.ts.js”

typeScrip 类

包管理器:Bower vs jspm