要求JS - $(...).DataTable不是一个函数

3

我在使用jQuery DataTables时遇到了很多麻烦。我已经在许多地方寻找答案,但似乎一直无法解决问题。

通过Chrome开发者工具,我收到的错误信息是:

$(...).DataTable不是一个函数

app.js:

requirejs.config({
    "baseUrl": "../Scripts",
    "paths": {
        app: "./app",
        essentials: "./dist/essentials.min",
        jquery: "./dist/jquery-1.10.2.min",
        "jquery.bootstrap": "./dist/bootstrap.min"
        "jquery.dataTables": "./dist/jquery.dataTables.min",
        "jquery.dataTables.bootstrap": "./dist/jquery.dataTables.bootstrap.min"

    },
    "shim": {
        "essentials": ["jquery"],
        "jquery.dataTables": ["jquery"],
        "jquery.dataTables.bootstrap": ["jquery.dataTables"],
        "jquery.bootstrap": ["jquery"]
    }
});

// Load the main app module to start the app
requirejs(["app/main"]);

main.js(未使用):

require(["jquery"], function ($) {
    $(function () {
    });
});

Create.js(由TypeScript生成):

define(["require", "exports", "../../Shared/ModalHelper"], function (require, exports, Helper) {
    require(["jquery", "essentials", "jquery.bootstrap", "jquery.dataTables", "jquery.dataTables.bootstrap"], function ($) {
        function initilializeTables() {
            var attrSelectDataTable = $('#selectAttrsTable').DataTable({
                paging: true,
                bInfo: true,
                "columnDefs": [
                    { "orderable": false, "targets": 0 }
                ],
                scrollY: 400
            });
            var attrPreviewDataTable = $('#selectedAttrsTable').DataTable({
                paging: true,
                bInfo: true,
                "columnDefs": [
                    { "orderable": false, "targets": 0 },
                    { "orderable": false, "targets": 5 }
                ],
                scrollY: 400
            });

        }

        initilializeTables();

    });
});
2个回答

1
由于DataTables声明自己为命名模块,因此在声明require config路径名称时必须使用“datatables”名称。
这里有一个实时示例。感谢这里的贡献。

0

出错的原因很可能是:

  • 缺少jQuery库(./dist/jquery-1.10.2.min.js

    或者

  • 缺少jQuery DataTables插件(./dist/jquery.dataTables.min.js

    或者

  • jQuery DataTables版本为1.9.x或更低。 jquery.dataTables.min.js的第一行应包含插件版本。

    DataTable()方法仅适用于jQuery DataTables 1.10及以上版本。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接