javascript - 无法在 TS 脚本中导入 Bootstrap 库

标签 javascript twitter-bootstrap typescript

我遇到了一个问题,我似乎无法在我的 typescript 文件中导入 bootstrapjs。我需要这个来打开模式。

我的 typescript 脚本:

import $ from 'jquery';
import 'bootstrap';

$('#btn').click(function () {
    $('#test').text('sasasa');
});

我的观点

<button type="button" class="btn btn-info btn-lg" data-toggle="modal" data-target="#myModal">Open Modal</button>

<div id="myModal" class="modal fade" role="dialog">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal">&times;</button>
                <h4 class="modal-title">Modal Header</h4>
            </div>
            <div class="modal-body">
                <p>Some text in the modal.</p>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
            </div>
        </div>
    </div>
</div>

<div class="row">
    <div class="panel panel-default">
        <div class="panel-heading">
            <h3 class="panel-title">
                test
            </h3>
        </div>
        <div class="panel-body">
            <span id="test">Test</span>

            <button id="btn">Klik</button>
        </div>
    </div>
</div>

@section scripts {
    <environment names="Development">
        <script src="~/js/quotation-test.js"></script>
    </environment>
    <environment names="Staging,Production">
        <script src="~/js/quotation-test.js" asp-append-version="true"></script>
    </environment>
}

当我在 typescript 脚本之上运行时,我在控制台中收到以下错误:

Uncaught ReferenceError: jQuery is not defined
    at Object.562 (quotation-test.js:103)
    at __webpack_require__ (common.js:55)
    at Object.561 (quotation-test.js:27)
    at __webpack_require__ (common.js:55)
    at Object.560 (quotation-test.js:13)
    at __webpack_require__ (common.js:55)
    at webpackJsonpCallback (common.js:26)
    at quotation-test.js:1

但是,当我删除 import 'bootstrap' 行时,btn 单击处理程序工作正常。所以看起来 jQuery 被正确导入了。

手动添加脚本(即:)

<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<!-- jQuery library -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>

<!-- Latest compiled JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

模式工作正常,但我宁愿不走那条路。有没有人有什么建议?我在网上找不到任何似乎有同样问题的资源。

我的(相关部分)package.json:

    "@types/bootstrap": "^3.3.36",
    "bootstrap": "^3.3.7",
    "jquery": "^3.2.1",

有人有什么建议吗?任何帮助将不胜感激。

最佳答案

当使用 ES6/CommonJS 导入 jQuery 时,它不会创建 bootstrap 包所依赖的全局变量。您需要显式创建全局 jQuery 变量,以便 Bootstrap 可以使用它:

import $ from 'jquery';
window['jQuery'] = $;
import 'bootstrap';

关于javascript - 无法在 TS 脚本中导入 Bootstrap 库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46234567/

相关文章:

javascript - 将 'type' 属性添加到 dll 加载的脚本标记中

css - 禁用按钮在禁用时隐藏

typescript - 如何在 TypeScript 中定义树类型?

javascript - 在 Typescript 中,扩展 Array 结果为 Array 类型,如何让它返回 List 类型?

typescript - 在 Typescript 中混入抽象基类

javascript - 等待 javascript 函数返回

javascript - 如何使用 jquery 处理 google recapcha?

javascript - jQuery 选择模式

javascript - Bootstrap Material 设计无法在动态 Angular View 中正常工作

javascript - 按嵌套的相关数组元素对数组进行分组