使用RequireJS

时间:2015-12-17 17:38:09

标签: javascript jquery twitter-bootstrap knockout.js requirejs

我有一个针对bootstrap工具提示的自定义knockout绑定,有时候页面加载很好,有时我会在绑定中抛出这个错误。

  

$(...)。tooltip不是函数

我在发生这种情况的部分设置了一个断点,有时jquery对象上没有任何引导函数。我只能假设这是由require加载引导程序库的时间问题。就像我说的那样,每次都不会发生这种情况,而且当开启dev工具控制台时,它似乎经常发生。

这是我的require config

requirejs.config({
    waitSeconds: 200,
    shim: {
        "bootstrap": {
            deps: ['jquery'],
            exports: "$.fn.tooltip"
        }
    },
    enforceDefine: true,
    paths: {
        jquery: 'jquery-1.11.3.min',
        bootstrap: 'bootstrap.min',
        moment: 'moment.min',
        knockout: 'knockout.min',
        appVM: 'appVM',
        custombindings: 'custombindings'
    }
});

我的约束力

define(['knockout', 'jquery', 'bootstrap'], function (ko, $, bootstrap) {
    ko.bindingHandlers.tooltip = {
        init: function (element, valueAccessor) {
            var local = ko.utils.unwrapObservable(valueAccessor()),
                options = {};

            ko.utils.extend(options, ko.bindingHandlers.tooltip.options);
            ko.utils.extend(options, local);

            $(element).tooltip(options);  //Error thrown here

            ko.utils.domNodeDisposal.addDisposeCallback(element, function () {
                $(element).tooltip("destroy");
            });
        },
        options: {
            'container': 'body',
            'delay': { 'show': 1000, 'hide': 100 },
            'animation': 'true'
        }
    };
});

我的申请绑定

define(['jquery', 'bootstrap', 'appVM', 'knockout', 'domReady!'], 
    function(jquery, bootstrap, appVM, ko) {
    var vm = new appVM();
    ko.applyBindings(vm);
});

1 个答案:

答案 0 :(得分:4)

customBindings添加到调用ko.applyBindings

的模块中的依赖项列表中
define(['jquery', 'bootstrap', 'appVM', 'knockout', 'customBindings', 'domReady!'],
    function(jquery, bootstrap, appVM, ko) {
    var vm = new appVM();
    ko.applyBindings(vm);
});