2

主.js:

 requirejs.config({
   enforceDefine: true,
   paths: {
     "jquery": "libs/jquery/jquery-min",
     "underscore": "libs/underscore/underscore-min",
     "backbone": "libs/backbone/backbone-min",
     "jquery.pnotify":"libs/jquery/jquery.pnotify.min"

},
shim: {
   "underscore": {
       deps: [],
       exports: "_"
    },
   "backbone": {
       deps: ["jquery", "underscore"],
       exports: "Backbone"
    },
   "jquery.pnotify" : {
       deps : ["jquery"],
       exports : "jQuery.fn.pnotify"
    }
  }
});

看法 :

define(["jquery" ,
       "underscore" ,
       "backbone" ,
       "jquery.pnotify",
       "models/CartModel" ,
        ],function($ , _ , Backbone , Cart ){

var CartView = Backbone.View.extend({
    initialize: function() {
        this.updateQtyLabel("qtyCart");
    },
    el: '.addToCart-form',
    events : {
        "click #addToCart" : "addToCart"
    },
    addToCart : function (){
        $.pnotify({
            title: 'Go to Cart and Check Out',
            text: '1 item added to Cart',
            shadow:false,
            delay:1000
        });
    },
    render: function(){

    }
});
return CartView;
});

我有一个错误Uncaught Error: No define call for jquery.pnotify

任何帮助深表感谢。

4

1 回答 1

1

你已经导入了 pnotify,但是你没有为它声明一个变量。改变

function($ , _ , Backbone , Cart ){

function($ , _ , Backbone , pnotify, Cart ){

请注意,您调用变量实际上并不重要,因为无论如何您都不会使用它。严格来说,你甚至不需要定义变量——jQuery 插件只存在于你已经定义的 jQuery 命名空间中——除了你使用enforceDefine = true. 但是,如果您要删除该属性,您也可以删除 shim 配置中的 exports 属性。只需确保任何“无导出”模块都位于最后一个具有真正导出功能的模块之后。

于 2013-12-06T16:27:09.057 回答